@dxos/plugin-kanban 0.8.1 → 0.8.2-main.10c050d
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/{artifact-definition-SVNHDJQT.mjs → artifact-definition-7AVKC5KJ.mjs} +24 -23
- package/dist/lib/browser/artifact-definition-7AVKC5KJ.mjs.map +7 -0
- package/dist/lib/browser/{chunk-K5BYEZ4Z.mjs → chunk-NJ6WHYLY.mjs} +25 -40
- package/dist/lib/browser/chunk-NJ6WHYLY.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +4 -4
- package/dist/lib/browser/intent-resolver-2R6I36UA.mjs +297 -0
- package/dist/lib/browser/intent-resolver-2R6I36UA.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-surface-W43CBHJ2.mjs +328 -0
- package/dist/lib/browser/react-surface-W43CBHJ2.mjs.map +7 -0
- package/dist/lib/browser/types.mjs +1 -3
- package/dist/lib/node/{artifact-definition-M2XAYUI2.cjs → artifact-definition-GAKXWPS3.cjs} +32 -31
- package/dist/lib/node/artifact-definition-GAKXWPS3.cjs.map +7 -0
- package/dist/lib/node/{chunk-3EUR6ZR2.cjs → chunk-3BKBOGOH.cjs} +27 -43
- package/dist/lib/node/chunk-3BKBOGOH.cjs.map +7 -0
- package/dist/lib/node/index.cjs +16 -16
- package/dist/lib/node/intent-resolver-3WEAK7UE.cjs +308 -0
- package/dist/lib/node/intent-resolver-3WEAK7UE.cjs.map +7 -0
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/react-surface-YEBNJKHD.cjs +344 -0
- package/dist/lib/node/react-surface-YEBNJKHD.cjs.map +7 -0
- package/dist/lib/node/types.cjs +6 -8
- package/dist/lib/node/types.cjs.map +2 -2
- package/dist/lib/node-esm/{artifact-definition-HQ5I2OO5.mjs → artifact-definition-RH5KY7FP.mjs} +24 -23
- package/dist/lib/node-esm/artifact-definition-RH5KY7FP.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-2N7CO3DI.mjs → chunk-4J76H6FE.mjs} +25 -40
- package/dist/lib/node-esm/chunk-4J76H6FE.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +4 -4
- package/dist/lib/node-esm/intent-resolver-XHHFK6V7.mjs +298 -0
- package/dist/lib/node-esm/intent-resolver-XHHFK6V7.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/react-surface-Q73OORPI.mjs +329 -0
- package/dist/lib/node-esm/react-surface-Q73OORPI.mjs.map +7 -0
- package/dist/lib/node-esm/types.mjs +1 -3
- package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +1 -1
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts +2 -2
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/components/KanbanContainer.d.ts.map +1 -1
- package/dist/types/src/components/KanbanContainer.stories.d.ts +10 -0
- package/dist/types/src/components/KanbanContainer.stories.d.ts.map +1 -0
- package/dist/types/src/components/KanbanViewEditor.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/testing/index.d.ts +3 -0
- package/dist/types/src/testing/index.d.ts.map +1 -0
- package/dist/types/src/testing/initialize-kanban.d.ts +17 -0
- package/dist/types/src/testing/initialize-kanban.d.ts.map +1 -0
- package/dist/types/src/testing/kanban-manager.d.ts +7 -0
- package/dist/types/src/testing/kanban-manager.d.ts.map +1 -0
- package/dist/types/src/testing/playwright/smoke.spec.d.ts +2 -0
- package/dist/types/src/testing/playwright/smoke.spec.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts +2 -28
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types.d.ts +34 -50
- package/dist/types/src/types.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +33 -26
- package/src/capabilities/artifact-definition.ts +15 -14
- package/src/capabilities/intent-resolver.ts +10 -6
- package/src/capabilities/react-surface.tsx +46 -12
- package/src/components/KanbanContainer.stories.tsx +191 -0
- package/src/components/KanbanContainer.tsx +24 -11
- package/src/components/KanbanViewEditor.tsx +12 -8
- package/src/meta.ts +1 -2
- package/src/testing/index.ts +6 -0
- package/src/testing/initialize-kanban.ts +139 -0
- package/src/testing/kanban-manager.ts +13 -0
- package/src/testing/playwright/playwright.config.cts +18 -0
- package/src/testing/playwright/smoke.spec.ts +7 -0
- package/src/types.ts +26 -43
- package/dist/lib/browser/artifact-definition-SVNHDJQT.mjs.map +0 -7
- package/dist/lib/browser/chunk-K5BYEZ4Z.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-XCDQ5N3Q.mjs +0 -132
- package/dist/lib/browser/intent-resolver-XCDQ5N3Q.mjs.map +0 -7
- package/dist/lib/browser/react-surface-5DLU7L63.mjs +0 -281
- package/dist/lib/browser/react-surface-5DLU7L63.mjs.map +0 -7
- package/dist/lib/node/artifact-definition-M2XAYUI2.cjs.map +0 -7
- package/dist/lib/node/chunk-3EUR6ZR2.cjs.map +0 -7
- package/dist/lib/node/intent-resolver-P3PSZO7H.cjs +0 -146
- package/dist/lib/node/intent-resolver-P3PSZO7H.cjs.map +0 -7
- package/dist/lib/node/react-surface-OWAYP7VQ.cjs +0 -297
- package/dist/lib/node/react-surface-OWAYP7VQ.cjs.map +0 -7
- package/dist/lib/node-esm/artifact-definition-HQ5I2OO5.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-2N7CO3DI.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-4G47V67J.mjs +0 -133
- package/dist/lib/node-esm/intent-resolver-4G47V67J.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-CLEITUUD.mjs +0 -282
- package/dist/lib/node-esm/react-surface-CLEITUUD.mjs.map +0 -7
|
@@ -2,12 +2,13 @@
|
|
|
2
2
|
// Copyright 2024 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import React, { useCallback, useEffect, useState } from 'react';
|
|
5
|
+
import React, { useCallback, useEffect, useMemo, useState } from 'react';
|
|
6
6
|
|
|
7
7
|
import { createIntent, useIntentDispatcher } from '@dxos/app-framework';
|
|
8
|
-
import { type
|
|
8
|
+
import { EchoSchema, getTypenameOrThrow, toJsonSchema, type TypedObject } from '@dxos/echo-schema';
|
|
9
9
|
import { useGlobalFilteredObjects } from '@dxos/plugin-search';
|
|
10
|
-
import {
|
|
10
|
+
import { useClient } from '@dxos/react-client';
|
|
11
|
+
import { Filter, useQuery, getSpace, live } from '@dxos/react-client/echo';
|
|
11
12
|
import { type KanbanType, useKanbanModel, Kanban } from '@dxos/react-ui-kanban';
|
|
12
13
|
import { StackItem } from '@dxos/react-ui-stack';
|
|
13
14
|
import { ViewProjection } from '@dxos/schema';
|
|
@@ -15,14 +16,26 @@ import { ViewProjection } from '@dxos/schema';
|
|
|
15
16
|
import { KanbanAction } from '../types';
|
|
16
17
|
|
|
17
18
|
export const KanbanContainer = ({ kanban }: { kanban: KanbanType; role: string }) => {
|
|
18
|
-
const
|
|
19
|
+
const client = useClient();
|
|
20
|
+
const [cardSchema, setCardSchema] = useState<TypedObject<any, any>>();
|
|
19
21
|
const [projection, setProjection] = useState<ViewProjection>();
|
|
20
22
|
const space = getSpace(kanban);
|
|
21
23
|
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
22
24
|
|
|
25
|
+
const jsonSchema = useMemo(
|
|
26
|
+
() =>
|
|
27
|
+
cardSchema instanceof EchoSchema ? cardSchema.jsonSchema : cardSchema ? toJsonSchema(cardSchema) : undefined,
|
|
28
|
+
[cardSchema],
|
|
29
|
+
);
|
|
30
|
+
|
|
23
31
|
useEffect(() => {
|
|
24
|
-
|
|
25
|
-
|
|
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 });
|
|
26
39
|
const unsubscribe = query.subscribe(
|
|
27
40
|
() => {
|
|
28
41
|
const [schema] = query.results;
|
|
@@ -37,13 +50,13 @@ export const KanbanContainer = ({ kanban }: { kanban: KanbanType; role: string }
|
|
|
37
50
|
}, [kanban.cardView?.target?.query, space]);
|
|
38
51
|
|
|
39
52
|
useEffect(() => {
|
|
40
|
-
if (kanban.cardView?.target &&
|
|
41
|
-
setProjection(new ViewProjection(
|
|
53
|
+
if (kanban.cardView?.target && jsonSchema) {
|
|
54
|
+
setProjection(new ViewProjection(jsonSchema, kanban.cardView.target));
|
|
42
55
|
}
|
|
43
56
|
// TODO(ZaymonFC): Is there a better way to get notified about deep changes in the json schema?
|
|
44
|
-
}, [kanban.cardView?.target,
|
|
57
|
+
}, [kanban.cardView?.target, JSON.stringify(jsonSchema)]);
|
|
45
58
|
|
|
46
|
-
const objects = useQuery(space, cardSchema ? Filter.
|
|
59
|
+
const objects = useQuery(space, cardSchema ? Filter.type(cardSchema) : Filter.nothing());
|
|
47
60
|
const filteredObjects = useGlobalFilteredObjects(objects);
|
|
48
61
|
|
|
49
62
|
const model = useKanbanModel({
|
|
@@ -57,7 +70,7 @@ export const KanbanContainer = ({ kanban }: { kanban: KanbanType; role: string }
|
|
|
57
70
|
(columnValue: string | undefined) => {
|
|
58
71
|
const path = model?.columnFieldPath;
|
|
59
72
|
if (space && cardSchema && path) {
|
|
60
|
-
const card =
|
|
73
|
+
const card = live(cardSchema, { [path]: columnValue });
|
|
61
74
|
space.db.add(card);
|
|
62
75
|
return card.id;
|
|
63
76
|
}
|
|
@@ -5,7 +5,8 @@
|
|
|
5
5
|
import React, { useCallback, useMemo } from 'react';
|
|
6
6
|
|
|
7
7
|
import { createIntent, useIntentDispatcher } from '@dxos/app-framework';
|
|
8
|
-
import {
|
|
8
|
+
import { Type } from '@dxos/echo';
|
|
9
|
+
import { assertEchoSchema, FormatEnum, isMutable } from '@dxos/echo-schema';
|
|
9
10
|
import { invariant } from '@dxos/invariant';
|
|
10
11
|
import { useClient } from '@dxos/react-client';
|
|
11
12
|
import { Filter, getSpace, useQuery, useSchema } from '@dxos/react-client/echo';
|
|
@@ -26,7 +27,7 @@ export const KanbanViewEditor = ({ kanban }: KanbanViewEditorProps) => {
|
|
|
26
27
|
[kanban?.cardView?.target?.query?.typename],
|
|
27
28
|
);
|
|
28
29
|
const schema = useSchema(client, space, currentTypename);
|
|
29
|
-
const views = useQuery(space, Filter.
|
|
30
|
+
const views = useQuery(space, Filter.type(ViewType));
|
|
30
31
|
|
|
31
32
|
const handleUpdateTypename = useCallback(
|
|
32
33
|
(newTypename: string) => {
|
|
@@ -36,7 +37,7 @@ export const KanbanViewEditor = ({ kanban }: KanbanViewEditorProps) => {
|
|
|
36
37
|
view.query.typename = newTypename;
|
|
37
38
|
}
|
|
38
39
|
|
|
39
|
-
schema.
|
|
40
|
+
assertEchoSchema(schema).updateTypename(newTypename);
|
|
40
41
|
},
|
|
41
42
|
[views, schema],
|
|
42
43
|
);
|
|
@@ -50,9 +51,10 @@ export const KanbanViewEditor = ({ kanban }: KanbanViewEditorProps) => {
|
|
|
50
51
|
|
|
51
52
|
const projection = useMemo(() => {
|
|
52
53
|
if (kanban?.cardView?.target && schema) {
|
|
53
|
-
|
|
54
|
+
const jsonSchema = Type.toJsonSchema(schema);
|
|
55
|
+
return new ViewProjection(jsonSchema, kanban.cardView.target);
|
|
54
56
|
}
|
|
55
|
-
}, [kanban?.cardView?.target, schema, JSON.stringify(schema)]);
|
|
57
|
+
}, [kanban?.cardView?.target, schema, JSON.stringify(schema ? Type.toJsonSchema(schema) : {})]);
|
|
56
58
|
|
|
57
59
|
const fieldProjections = projection?.getFieldProjections() || [];
|
|
58
60
|
const selectFields = fieldProjections
|
|
@@ -78,13 +80,15 @@ export const KanbanViewEditor = ({ kanban }: KanbanViewEditorProps) => {
|
|
|
78
80
|
|
|
79
81
|
return (
|
|
80
82
|
<>
|
|
81
|
-
<
|
|
83
|
+
<div role='none' className='p-2'>
|
|
84
|
+
<Form schema={KanbanSettingsSchema} values={initialValues} onSave={onSave} autoSave Custom={custom} />
|
|
85
|
+
</div>
|
|
82
86
|
<ViewEditor
|
|
83
87
|
registry={space.db.schemaRegistry}
|
|
84
88
|
schema={schema}
|
|
85
89
|
view={kanban.cardView.target}
|
|
86
|
-
onTypenameChanged={schema
|
|
87
|
-
onDelete={schema
|
|
90
|
+
onTypenameChanged={isMutable(schema) ? handleUpdateTypename : undefined}
|
|
91
|
+
onDelete={isMutable(schema) ? handleDelete : undefined}
|
|
88
92
|
/>
|
|
89
93
|
</>
|
|
90
94
|
);
|
package/src/meta.ts
CHANGED
|
@@ -12,7 +12,6 @@ export const meta: PluginMeta = {
|
|
|
12
12
|
description:
|
|
13
13
|
'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.',
|
|
14
14
|
icon: 'ph--kanban--regular',
|
|
15
|
-
source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/
|
|
16
|
-
tags: ['experimental'],
|
|
15
|
+
source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-kanban',
|
|
17
16
|
screenshots: ['https://dxos.network/plugin-details-kanban-dark.png'],
|
|
18
17
|
};
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2024 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { Schema } from 'effect';
|
|
6
|
+
|
|
7
|
+
import {
|
|
8
|
+
TypedObject,
|
|
9
|
+
FormatEnum,
|
|
10
|
+
TypeEnum,
|
|
11
|
+
type JsonProp,
|
|
12
|
+
type EchoSchema,
|
|
13
|
+
getTypenameOrThrow,
|
|
14
|
+
toJsonSchema,
|
|
15
|
+
} from '@dxos/echo-schema';
|
|
16
|
+
import { invariant } from '@dxos/invariant';
|
|
17
|
+
import { type Client, PublicKey } from '@dxos/react-client';
|
|
18
|
+
import { type Space, 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
|
+
|
|
23
|
+
// TODO(wittjosiah): UI package shouldn't depend on client.
|
|
24
|
+
|
|
25
|
+
type InitializeKanbanProps = {
|
|
26
|
+
client: Client;
|
|
27
|
+
space: Space;
|
|
28
|
+
name?: string;
|
|
29
|
+
typename?: string;
|
|
30
|
+
initialPivotColumn?: string;
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
const createDefaultTaskSchema = () => {
|
|
34
|
+
const stateOptions = [
|
|
35
|
+
{ id: PublicKey.random().truncate(), title: 'Draft', color: 'indigo' },
|
|
36
|
+
{ id: PublicKey.random().truncate(), title: 'Active', color: 'cyan' },
|
|
37
|
+
{ id: PublicKey.random().truncate(), title: 'Completed', color: 'emerald' },
|
|
38
|
+
];
|
|
39
|
+
|
|
40
|
+
const schema = TypedObject({
|
|
41
|
+
typename: `example.com/type/${PublicKey.random().truncate()}`,
|
|
42
|
+
version: '0.1.0',
|
|
43
|
+
})({
|
|
44
|
+
title: Schema.optional(Schema.String).annotations({
|
|
45
|
+
title: 'Title',
|
|
46
|
+
}),
|
|
47
|
+
description: Schema.optional(Schema.String).annotations({
|
|
48
|
+
title: 'Description',
|
|
49
|
+
}),
|
|
50
|
+
state: Schema.optional(Schema.String),
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
return { schema, stateOptions };
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
export const initializeKanban = async ({
|
|
57
|
+
client,
|
|
58
|
+
space,
|
|
59
|
+
name,
|
|
60
|
+
typename,
|
|
61
|
+
initialPivotColumn,
|
|
62
|
+
}: InitializeKanbanProps): Promise<{ kanban: KanbanType; schema?: EchoSchema }> => {
|
|
63
|
+
if (typename) {
|
|
64
|
+
const staticSchema = client.graph.schemaRegistry.schemas.find((schema) => getTypenameOrThrow(schema) === typename);
|
|
65
|
+
const schema = await space.db.schemaRegistry.query({ typename }).firstOrUndefined();
|
|
66
|
+
|
|
67
|
+
const ast = staticSchema?.ast ?? schema?.ast;
|
|
68
|
+
const jsonSchema = staticSchema ? toJsonSchema(staticSchema) : schema?.jsonSchema;
|
|
69
|
+
invariant(ast, `Schema not found: ${typename}`);
|
|
70
|
+
invariant(jsonSchema, `Schema not found: ${typename}`);
|
|
71
|
+
|
|
72
|
+
const fields = getSchemaProperties(ast)
|
|
73
|
+
.filter((prop) => prop.type !== 'object' || prop.format === FormatEnum.Ref)
|
|
74
|
+
.map((prop) => prop.name);
|
|
75
|
+
|
|
76
|
+
const view = createView({
|
|
77
|
+
name: "Kanban's card view",
|
|
78
|
+
typename,
|
|
79
|
+
jsonSchema,
|
|
80
|
+
fields,
|
|
81
|
+
});
|
|
82
|
+
|
|
83
|
+
const kanban = live(KanbanType, { cardView: makeRef(view), columnFieldId: undefined, name });
|
|
84
|
+
if (initialPivotColumn) {
|
|
85
|
+
const viewProjection = new ViewProjection(jsonSchema, view);
|
|
86
|
+
const fieldId = viewProjection.getFieldId(initialPivotColumn);
|
|
87
|
+
if (fieldId) {
|
|
88
|
+
kanban.columnFieldId = fieldId;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
return { kanban, schema };
|
|
92
|
+
} else {
|
|
93
|
+
const { schema: taskSchema, stateOptions } = createDefaultTaskSchema();
|
|
94
|
+
const [schema] = await space.db.schemaRegistry.register([taskSchema]);
|
|
95
|
+
|
|
96
|
+
const view = createView({
|
|
97
|
+
name: "Kanban's card view",
|
|
98
|
+
typename: schema.typename,
|
|
99
|
+
jsonSchema: schema.jsonSchema,
|
|
100
|
+
fields: ['title', 'description'],
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
const viewProjection = new ViewProjection(schema.jsonSchema, view);
|
|
104
|
+
|
|
105
|
+
// Set description field to Markdown format.
|
|
106
|
+
const descriptionFieldId = viewProjection.getFieldId('description');
|
|
107
|
+
if (descriptionFieldId) {
|
|
108
|
+
const fieldProjection = viewProjection.getFieldProjection(descriptionFieldId);
|
|
109
|
+
if (fieldProjection) {
|
|
110
|
+
viewProjection.setFieldProjection({
|
|
111
|
+
...fieldProjection,
|
|
112
|
+
props: { ...fieldProjection.props, format: FormatEnum.Markdown },
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
const initialPivotField = 'state';
|
|
118
|
+
viewProjection.setFieldProjection({
|
|
119
|
+
field: {
|
|
120
|
+
id: createFieldId(),
|
|
121
|
+
path: initialPivotField as JsonProp,
|
|
122
|
+
size: 150,
|
|
123
|
+
},
|
|
124
|
+
props: {
|
|
125
|
+
property: initialPivotField as JsonProp,
|
|
126
|
+
type: TypeEnum.String,
|
|
127
|
+
format: FormatEnum.SingleSelect,
|
|
128
|
+
title: capitalize(initialPivotField),
|
|
129
|
+
options: stateOptions,
|
|
130
|
+
},
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
const fieldId = viewProjection.getFieldId(initialPivotField);
|
|
134
|
+
invariant(fieldId);
|
|
135
|
+
|
|
136
|
+
const kanban = live(KanbanType, { cardView: makeRef(view), columnFieldId: fieldId });
|
|
137
|
+
return { kanban, schema };
|
|
138
|
+
}
|
|
139
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2023 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { nxE2EPreset } from '@nx/playwright/preset';
|
|
6
|
+
import { defineConfig } from '@playwright/test';
|
|
7
|
+
|
|
8
|
+
import { e2ePreset } from '@dxos/test-utils/playwright';
|
|
9
|
+
|
|
10
|
+
export default defineConfig({
|
|
11
|
+
...nxE2EPreset(__filename, { testDir: __dirname }),
|
|
12
|
+
...e2ePreset(__dirname),
|
|
13
|
+
webServer: {
|
|
14
|
+
command: 'pnpm -w nx storybook-e2e stories',
|
|
15
|
+
port: 9009,
|
|
16
|
+
reuseExistingServer: !process.env.CI,
|
|
17
|
+
},
|
|
18
|
+
});
|
package/src/types.ts
CHANGED
|
@@ -2,12 +2,10 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import {
|
|
5
|
+
import { Schema } from 'effect';
|
|
6
6
|
|
|
7
|
-
import {
|
|
8
|
-
import { type Space, SpaceSchema } from '@dxos/react-client/echo';
|
|
7
|
+
import { SpaceSchema } from '@dxos/react-client/echo';
|
|
9
8
|
import { KanbanType } from '@dxos/react-ui-kanban';
|
|
10
|
-
import { initializeKanban } from '@dxos/react-ui-kanban/testing';
|
|
11
9
|
import { FieldSchema } from '@dxos/schema';
|
|
12
10
|
|
|
13
11
|
import { KANBAN_PLUGIN } from './meta';
|
|
@@ -25,57 +23,57 @@ import { KANBAN_PLUGIN } from './meta';
|
|
|
25
23
|
export const TypenameAnnotationId = Symbol.for('@dxos/plugin-kanban/annotation/Typename');
|
|
26
24
|
export const PivotColumnAnnotationId = Symbol.for('@dxos/plugin-kanban/annotation/PivotColumn');
|
|
27
25
|
|
|
28
|
-
export const CreateKanbanSchema =
|
|
29
|
-
name:
|
|
30
|
-
typename:
|
|
31
|
-
|
|
26
|
+
export const CreateKanbanSchema = Schema.Struct({
|
|
27
|
+
name: Schema.optional(Schema.String),
|
|
28
|
+
typename: Schema.optional(
|
|
29
|
+
Schema.String.annotations({
|
|
32
30
|
[TypenameAnnotationId]: true,
|
|
33
|
-
|
|
31
|
+
title: 'Select card schema (leave empty to start fresh)',
|
|
34
32
|
}),
|
|
35
33
|
),
|
|
36
|
-
initialPivotColumn:
|
|
37
|
-
|
|
34
|
+
initialPivotColumn: Schema.optional(
|
|
35
|
+
Schema.String.annotations({
|
|
38
36
|
[PivotColumnAnnotationId]: true,
|
|
39
|
-
|
|
37
|
+
title: 'Pivot column',
|
|
40
38
|
}),
|
|
41
39
|
),
|
|
42
40
|
});
|
|
43
41
|
|
|
44
|
-
export type CreateKanbanType =
|
|
42
|
+
export type CreateKanbanType = Schema.Schema.Type<typeof CreateKanbanSchema>;
|
|
45
43
|
|
|
46
44
|
export namespace KanbanAction {
|
|
47
45
|
const KANBAN_ACTION = `${KANBAN_PLUGIN}/action`;
|
|
48
46
|
|
|
49
|
-
export class Create extends
|
|
50
|
-
input:
|
|
51
|
-
output:
|
|
47
|
+
export class Create extends Schema.TaggedClass<Create>()(`${KANBAN_ACTION}/create`, {
|
|
48
|
+
input: Schema.extend(Schema.Struct({ space: SpaceSchema }), CreateKanbanSchema),
|
|
49
|
+
output: Schema.Struct({
|
|
52
50
|
object: KanbanType,
|
|
53
51
|
}),
|
|
54
52
|
}) {}
|
|
55
53
|
|
|
56
|
-
export class DeleteCardField extends
|
|
57
|
-
input:
|
|
54
|
+
export class DeleteCardField extends Schema.TaggedClass<DeleteCardField>()(`${KANBAN_ACTION}/delete-card-field`, {
|
|
55
|
+
input: Schema.Struct({
|
|
58
56
|
kanban: KanbanType,
|
|
59
|
-
fieldId:
|
|
57
|
+
fieldId: Schema.String,
|
|
60
58
|
// TODO(wittjosiah): Separate fields for undo data?
|
|
61
|
-
deletionData:
|
|
62
|
-
|
|
59
|
+
deletionData: Schema.optional(
|
|
60
|
+
Schema.Struct({
|
|
63
61
|
field: FieldSchema,
|
|
64
62
|
// TODO(wittjosiah): This creates a type error.
|
|
65
63
|
// props: PropertySchema,
|
|
66
|
-
props:
|
|
67
|
-
index:
|
|
64
|
+
props: Schema.Any,
|
|
65
|
+
index: Schema.Number,
|
|
68
66
|
}),
|
|
69
67
|
),
|
|
70
68
|
}),
|
|
71
|
-
output:
|
|
69
|
+
output: Schema.Void,
|
|
72
70
|
}) {}
|
|
73
71
|
|
|
74
|
-
export class DeleteCard extends
|
|
75
|
-
input:
|
|
76
|
-
card:
|
|
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
|
|
77
75
|
}),
|
|
78
|
-
output:
|
|
76
|
+
output: Schema.Void,
|
|
79
77
|
}) {}
|
|
80
78
|
}
|
|
81
79
|
|
|
@@ -96,18 +94,3 @@ export type Location = {
|
|
|
96
94
|
};
|
|
97
95
|
|
|
98
96
|
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 { 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, S } 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 = S.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: S.Struct({\n typename: S.String.annotations({\n description: 'The fully qualified typename of the schema to use for the kanban cards.',\n }),\n pivotColumn: S.optional(S.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: S.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: S.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": ";;;;;;AAIA,SAASA,YAAY;AAErB,SAASC,cAAcC,OAAOC,aAAaC,oBAAkD;AAC7F,SAASC,gBAAgBC,YAAYC,kBAAkB;AACvD,SAASC,6BAA6B;AACtC,SAASC,cAAcC,SAAS;AAChC,SAASC,iBAAiB;AAC1B,SAASC,mBAAmB;AAC5B,SAASC,QAAQC,wBAAoC;AACrD,SAASC,kBAAkB;;AAK3B,IAAMC,cAAcC,EAAEC,OAAOC,YAAY;EACvCC,aAAa;AACf,CAAA;AASA,IAAA,8BAAe,MAAA;AACb,QAAMC,aAAaC,eAAe;IAChCC,IAAI,YAAYC,KAAKD,EAAE;IACvBE,MAAMD,KAAKC;IACXC,cAAc;;;;;IAKdC,QAAQC;IACRC,OAAO;MACLC,WAAWN,KAAKD,IAAI;QAClBE,MAAM;QACNL,aAAa;;;QAGbW,SAAS;QACTJ,QAAQV,EAAEe,OAAO;UACfC,UAAUhB,EAAEC,OAAOC,YAAY;YAC7BC,aAAa;UACf,CAAA;UACAc,aAAajB,EAAEkB,SAASlB,EAAEC,MAAM,EAAEC,YAAY;YAC5CC,aAAa;UACf,CAAA;QACF,CAAA;QACAgB,SAAS,OAAO,EAAEH,UAAUC,YAAW,GAAI,EAAEG,WAAU,MAAE;AACvDC,oBAAUD,YAAYE,OAAO,YAAA;;;;;;;;;AAC7BD,oBAAUD,YAAYG,UAAU,wBAAA;;;;;;;;;AAGhC,gBAAMb,SAAS,MAAMU,WAAWE,MAAME,GAAGC,eAAeC,MAAM;YAAEV;UAAS,CAAA,EAAGW,iBAAgB;AAC5F,cAAI,CAACjB,QAAQ;AACX,mBAAOkB,WAAWC,MAAM,qBAAqBb,QAAAA,EAAU;UACzD;AAEA,gBAAMc,SAASC,KACbC,aAAaC,aAAaC,QAAQ;YAChCZ,OAAOF,WAAWE;YAClBN;YACAmB,oBAAoBlB;UACtB,CAAA,GACAmB,MAAMC,YAAYC,WAAW;YAAEC,QAAQnB,WAAWE;UAAM,CAAA,CAAA;AAG1D,gBAAM,EAAEkB,MAAMC,MAAK,IAAK,MAAMrB,WAAWG,SAASO,MAAAA;AAClD,cAAI,CAACU,QAAQC,OAAO;AAClB,mBAAOb,WAAWC,MAAMY,OAAOC,WAAW,+BAAA;UAC5C;AAEA,iBAAOd,WAAWe,QAAQC,sBAAsBJ,KAAKlC,EAAE,CAAA;QACzD;MACF,CAAA;MACAO,WAAWN,KAAKD,IAAI;QAClBE,MAAM;QACNL,aAAa;QACbW,SAAS;QACTJ,QAAQV,EAAEe,OAAO,CAAC,CAAA;QAClBI,SAAS,OAAO0B,QAAQ,EAAEzB,WAAU,MAAE;AACpCC,oBAAUD,YAAYE,OAAO,YAAA;;;;;;;;;AAC7B,gBAAMA,QAAQF,WAAWE;AACzB,gBAAM,EAAEwB,SAASC,OAAM,IAAK,MAAMzB,MAAME,GAAGE,MAAMsB,OAAOtC,OAAOC,UAAAA,CAAAA,EAAasC,IAAG;AAE/E,gBAAMC,YAAY,MAAMC,QAAQC,IAC9BL,OAAOM,IAAI,OAAOC,UAAAA;AAChB,kBAAMC,OAAO,MAAMD,MAAME,UAAUC,KAAAA;AACnC,mBAAO;cACLnD,IAAIoD,iBAAiBJ,KAAAA;cACrBtC,UAAUuC,MAAM7B,MAAMV;YACxB;UACF,CAAA,CAAA;AAGF,iBAAOY,WAAWe,QAAQO,SAAAA;QAC5B;MACF,CAAA;MACArC,WAAWN,KAAKD,IAAI;QAClBE,MAAM;QACNL,aAAa;QACbW,SAAS;QACTJ,QAAQV,EAAEe,OAAO;UAAET,IAAIP;QAAY,CAAA;QACnCoB,SAAS,OAAO,EAAEb,GAAE,GAAI,EAAEc,WAAU,MAAE;AACpCC,oBAAUD,YAAYE,OAAO,YAAA;;;;;;;;;AAC7B,gBAAMA,QAAQF,WAAWE;AACzB,gBAAM,EAAEwB,SAASC,OAAM,IAAK,MAAMzB,MAAME,GAAGE,MAAMsB,OAAOtC,OAAOC,UAAAA,CAAAA,EAAasC,IAAG;AAC/E,gBAAMK,QAAQP,OAAOY,KAAK,CAACL,WAAsBI,iBAAiBJ,MAAAA,MAAWhD,EAAAA;AAC7Ee,oBAAUuC,aAAajD,YAAY2C,KAAAA,GAAAA,QAAAA;;;;;;;;;AAEnC,gBAAMC,OAAO,MAAMD,MAAME,UAAUC,KAAAA;AACnCpC,oBAAUkC,MAAAA,QAAAA;;;;;;;;;AAEV,gBAAMvC,WAAWuC,KAAK7B,MAAMV;AAC5B,gBAAMN,SAAS,MAAMY,MAAME,GAAGC,eAAeC,MAAM;YAAEV;UAAS,CAAA,EAAGW,iBAAgB;AACjFN,oBAAUX,QAAAA,QAAAA;;;;;;;;;AAEV,iBAAOkB,WAAWe,QAAQ;YACxBjC;YACAmD,aAAaP,MAAMQ;YACnBC,YAAYR,KAAKS;UACnB,CAAA;QACF;MACF,CAAA;;EAEJ,CAAA;AAEA,SAAOC,YAAYC,aAAaC,oBAAoB/D,UAAAA;AACtD;",
|
|
6
|
-
"names": ["pipe", "Capabilities", "chain", "contributes", "createIntent", "defineArtifact", "defineTool", "ToolResult", "createArtifactElement", "isInstanceOf", "S", "invariant", "SpaceAction", "Filter", "fullyQualifiedId", "KanbanType", "QualifiedId", "S", "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 { TitleAnnotationId } from 'effect/SchemaAST';\n\nimport { S } from '@dxos/echo-schema';\nimport { type Space, SpaceSchema } from '@dxos/react-client/echo';\nimport { KanbanType } from '@dxos/react-ui-kanban';\nimport { initializeKanban } from '@dxos/react-ui-kanban/testing';\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 = S.Struct({\n name: S.optional(S.String),\n typename: S.optional(\n S.String.annotations({\n [TypenameAnnotationId]: true,\n [TitleAnnotationId]: 'Select card schema (leave empty to start fresh)',\n }),\n ),\n initialPivotColumn: S.optional(\n S.String.annotations({\n [PivotColumnAnnotationId]: true,\n [TitleAnnotationId]: 'Pivot column',\n }),\n ),\n});\n\nexport type CreateKanbanType = S.Schema.Type<typeof CreateKanbanSchema>;\n\nexport namespace KanbanAction {\n const KANBAN_ACTION = `${KANBAN_PLUGIN}/action`;\n\n export class Create extends S.TaggedClass<Create>()(`${KANBAN_ACTION}/create`, {\n input: S.extend(S.Struct({ space: SpaceSchema }), CreateKanbanSchema),\n output: S.Struct({\n object: KanbanType,\n }),\n }) {}\n\n export class DeleteCardField extends S.TaggedClass<DeleteCardField>()(`${KANBAN_ACTION}/delete-card-field`, {\n input: S.Struct({\n kanban: KanbanType,\n fieldId: S.String,\n // TODO(wittjosiah): Separate fields for undo data?\n deletionData: S.optional(\n S.Struct({\n field: FieldSchema,\n // TODO(wittjosiah): This creates a type error.\n // props: PropertySchema,\n props: S.Any,\n index: S.Number,\n }),\n ),\n }),\n output: S.Void,\n }) {}\n\n export class DeleteCard extends S.TaggedClass<DeleteCard>()(`${KANBAN_ACTION}/delete-card`, {\n input: S.Struct({\n card: S.Any, // The card object to delete\n }),\n output: S.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\nexport const createKanban = async ({\n space,\n name,\n typename,\n initialPivotColumn,\n}: {\n space: Space;\n name?: string;\n typename?: string;\n initialPivotColumn?: string;\n}) => {\n const { kanban } = await initializeKanban({ space, name, typename, initialPivotColumn });\n return kanban;\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/experimental/plugin-kanban',\n tags: ['experimental'],\n screenshots: ['https://dxos.network/plugin-details-kanban-dark.png'],\n};\n"],
|
|
5
|
-
"mappings": ";AAIA,SAASA,yBAAyB;AAElC,SAASC,SAAS;AAClB,SAAqBC,mBAAmB;AACxC,SAASC,kBAAkB;AAC3B,SAASC,wBAAwB;AACjC,SAASC,mBAAmB;;;ACJrB,IAAMC,gBAAgB;AAEtB,IAAMC,OAAmB;EAC9BC,IAAIF;EACJG,MAAM;EACNC,aACE;EACFC,MAAM;EACNC,QAAQ;EACRC,MAAM;IAAC;;EACPC,aAAa;IAAC;;AAChB;;;ADOO,IAAMC,uBAAuBC,OAAOC,IAAI,yCAAA;AACxC,IAAMC,0BAA0BF,OAAOC,IAAI,4CAAA;AAE3C,IAAME,qBAAqBC,EAAEC,OAAO;EACzCC,MAAMF,EAAEG,SAASH,EAAEI,MAAM;EACzBC,UAAUL,EAAEG,SACVH,EAAEI,OAAOE,YAAY;IACnB,CAACX,oBAAAA,GAAuB;IACxB,CAACY,iBAAAA,GAAoB;EACvB,CAAA,CAAA;EAEFC,oBAAoBR,EAAEG,SACpBH,EAAEI,OAAOE,YAAY;IACnB,CAACR,uBAAAA,GAA0B;IAC3B,CAACS,iBAAAA,GAAoB;EACvB,CAAA,CAAA;AAEJ,CAAA;;UAIiBE,eAAAA;AACf,QAAMC,gBAAgB,GAAGC,aAAAA;EAElB,MAAMC,eAAeZ,EAAEa,YAAW,EAAW,GAAGH,aAAAA,WAAwB;IAC7EI,OAAOd,EAAEe,OAAOf,EAAEC,OAAO;MAAEe,OAAOC;IAAY,CAAA,GAAIlB,kBAAAA;IAClDmB,QAAQlB,EAAEC,OAAO;MACfkB,QAAQC;IACV,CAAA;EACF,CAAA,EAAA;EAAI;gBALSR,SAAAA;EAON,MAAMS,wBAAwBrB,EAAEa,YAAW,EAAoB,GAAGH,aAAAA,sBAAmC;IAC1GI,OAAOd,EAAEC,OAAO;MACdqB,QAAQF;MACRG,SAASvB,EAAEI;;MAEXoB,cAAcxB,EAAEG,SACdH,EAAEC,OAAO;QACPwB,OAAOC;;;QAGPC,OAAO3B,EAAE4B;QACTC,OAAO7B,EAAE8B;MACX,CAAA,CAAA;IAEJ,CAAA;IACAZ,QAAQlB,EAAE+B;EACZ,CAAA,EAAA;EAAI;gBAhBSV,kBAAAA;EAkBN,MAAMW,mBAAmBhC,EAAEa,YAAW,EAAe,GAAGH,aAAAA,gBAA6B;IAC1FI,OAAOd,EAAEC,OAAO;MACdgC,MAAMjC,EAAE4B;IACV,CAAA;IACAV,QAAQlB,EAAE+B;EACZ,CAAA,EAAA;EAAI;gBALSC,aAAAA;AAMf,GAlCiBvB,iBAAAA,eAAAA,CAAAA,EAAAA;AAoDV,IAAMyB,WAAW,CAACf,WAA0CA,UAAU,QAAQA,kBAAkBC;AAEhG,IAAMe,eAAe,OAAO,EACjCnB,OACAd,MACAG,UACAG,mBAAkB,MAMnB;AACC,QAAM,EAAEc,OAAM,IAAK,MAAMc,iBAAiB;IAAEpB;IAAOd;IAAMG;IAAUG;EAAmB,CAAA;AACtF,SAAOc;AACT;",
|
|
6
|
-
"names": ["TitleAnnotationId", "S", "SpaceSchema", "KanbanType", "initializeKanban", "FieldSchema", "KANBAN_PLUGIN", "meta", "id", "name", "description", "icon", "source", "tags", "screenshots", "TypenameAnnotationId", "Symbol", "for", "PivotColumnAnnotationId", "CreateKanbanSchema", "S", "Struct", "name", "optional", "String", "typename", "annotations", "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", "createKanban", "initializeKanban"]
|
|
7
|
-
}
|
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
KANBAN_PLUGIN,
|
|
3
|
-
KanbanAction,
|
|
4
|
-
createKanban
|
|
5
|
-
} from "./chunk-K5BYEZ4Z.mjs";
|
|
6
|
-
|
|
7
|
-
// packages/plugins/plugin-kanban/src/capabilities/intent-resolver.ts
|
|
8
|
-
import { contributes, Capabilities, createResolver } from "@dxos/app-framework";
|
|
9
|
-
import { invariant } from "@dxos/invariant";
|
|
10
|
-
import { getSpace } from "@dxos/react-client/echo";
|
|
11
|
-
import { ViewProjection } from "@dxos/schema";
|
|
12
|
-
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/plugin-kanban/src/capabilities/intent-resolver.ts";
|
|
13
|
-
var intent_resolver_default = () => contributes(Capabilities.IntentResolver, [
|
|
14
|
-
createResolver({
|
|
15
|
-
intent: KanbanAction.Create,
|
|
16
|
-
resolve: async ({ space, name, typename, initialPivotColumn }) => ({
|
|
17
|
-
data: {
|
|
18
|
-
object: await createKanban({
|
|
19
|
-
space,
|
|
20
|
-
name,
|
|
21
|
-
typename,
|
|
22
|
-
initialPivotColumn
|
|
23
|
-
})
|
|
24
|
-
}
|
|
25
|
-
})
|
|
26
|
-
}),
|
|
27
|
-
createResolver({
|
|
28
|
-
intent: KanbanAction.DeleteCardField,
|
|
29
|
-
resolve: ({ kanban, fieldId, deletionData }, undo) => {
|
|
30
|
-
invariant(kanban.cardView, void 0, {
|
|
31
|
-
F: __dxlog_file,
|
|
32
|
-
L: 24,
|
|
33
|
-
S: void 0,
|
|
34
|
-
A: [
|
|
35
|
-
"kanban.cardView",
|
|
36
|
-
""
|
|
37
|
-
]
|
|
38
|
-
});
|
|
39
|
-
invariant(kanban.cardView.target?.query.typename, void 0, {
|
|
40
|
-
F: __dxlog_file,
|
|
41
|
-
L: 25,
|
|
42
|
-
S: void 0,
|
|
43
|
-
A: [
|
|
44
|
-
"kanban.cardView.target?.query.typename",
|
|
45
|
-
""
|
|
46
|
-
]
|
|
47
|
-
});
|
|
48
|
-
const schema = kanban.cardView.target && getSpace(kanban)?.db.schemaRegistry.getSchema(kanban.cardView.target.query.typename);
|
|
49
|
-
invariant(schema, void 0, {
|
|
50
|
-
F: __dxlog_file,
|
|
51
|
-
L: 30,
|
|
52
|
-
S: void 0,
|
|
53
|
-
A: [
|
|
54
|
-
"schema",
|
|
55
|
-
""
|
|
56
|
-
]
|
|
57
|
-
});
|
|
58
|
-
invariant(kanban.cardView.target, void 0, {
|
|
59
|
-
F: __dxlog_file,
|
|
60
|
-
L: 31,
|
|
61
|
-
S: void 0,
|
|
62
|
-
A: [
|
|
63
|
-
"kanban.cardView.target",
|
|
64
|
-
""
|
|
65
|
-
]
|
|
66
|
-
});
|
|
67
|
-
const projection = new ViewProjection(schema.jsonSchema, kanban.cardView.target);
|
|
68
|
-
if (!undo) {
|
|
69
|
-
const { deleted, index } = projection.deleteFieldProjection(fieldId);
|
|
70
|
-
return {
|
|
71
|
-
undoable: {
|
|
72
|
-
message: [
|
|
73
|
-
"card field deleted label",
|
|
74
|
-
{
|
|
75
|
-
ns: KANBAN_PLUGIN
|
|
76
|
-
}
|
|
77
|
-
],
|
|
78
|
-
data: {
|
|
79
|
-
deletionData: {
|
|
80
|
-
...deleted,
|
|
81
|
-
index
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
};
|
|
86
|
-
} else if (undo && deletionData) {
|
|
87
|
-
const { field, props, index } = deletionData;
|
|
88
|
-
projection.setFieldProjection({
|
|
89
|
-
field,
|
|
90
|
-
props
|
|
91
|
-
}, index);
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
}),
|
|
95
|
-
createResolver({
|
|
96
|
-
intent: KanbanAction.DeleteCard,
|
|
97
|
-
resolve: ({ card }, undo) => {
|
|
98
|
-
const space = getSpace(card);
|
|
99
|
-
invariant(space, void 0, {
|
|
100
|
-
F: __dxlog_file,
|
|
101
|
-
L: 52,
|
|
102
|
-
S: void 0,
|
|
103
|
-
A: [
|
|
104
|
-
"space",
|
|
105
|
-
""
|
|
106
|
-
]
|
|
107
|
-
});
|
|
108
|
-
if (!undo) {
|
|
109
|
-
space.db.remove(card);
|
|
110
|
-
return {
|
|
111
|
-
undoable: {
|
|
112
|
-
message: [
|
|
113
|
-
"card deleted label",
|
|
114
|
-
{
|
|
115
|
-
ns: KANBAN_PLUGIN
|
|
116
|
-
}
|
|
117
|
-
],
|
|
118
|
-
data: {
|
|
119
|
-
card
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
};
|
|
123
|
-
} else {
|
|
124
|
-
space.db.add(card);
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
})
|
|
128
|
-
]);
|
|
129
|
-
export {
|
|
130
|
-
intent_resolver_default as default
|
|
131
|
-
};
|
|
132
|
-
//# sourceMappingURL=intent-resolver-XCDQ5N3Q.mjs.map
|
|
@@ -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 } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { getSpace } from '@dxos/react-client/echo';\nimport { ViewProjection } from '@dxos/schema';\n\nimport { KANBAN_PLUGIN } from '../meta';\nimport { createKanban, KanbanAction } from '../types';\n\nexport default () =>\n contributes(Capabilities.IntentResolver, [\n createResolver({\n intent: KanbanAction.Create,\n resolve: async ({ space, name, typename, initialPivotColumn }) => ({\n data: { object: await createKanban({ space, name, typename, initialPivotColumn }) },\n }),\n }),\n createResolver({\n intent: KanbanAction.DeleteCardField,\n resolve: ({ kanban, fieldId, deletionData }, undo) => {\n invariant(kanban.cardView);\n invariant(kanban.cardView.target?.query.typename);\n\n const schema =\n kanban.cardView.target &&\n getSpace(kanban)?.db.schemaRegistry.getSchema(kanban.cardView.target.query.typename);\n invariant(schema);\n invariant(kanban.cardView.target);\n const projection = new ViewProjection(schema.jsonSchema, kanban.cardView.target);\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,sBAAsB;AAC1D,SAASC,iBAAiB;AAC1B,SAASC,gBAAgB;AACzB,SAASC,sBAAsB;;AAK/B,IAAA,0BAAe,MACbC,YAAYC,aAAaC,gBAAgB;EACvCC,eAAe;IACbC,QAAQC,aAAaC;IACrBC,SAAS,OAAO,EAAEC,OAAOC,MAAMC,UAAUC,mBAAkB,OAAQ;MACjEC,MAAM;QAAEC,QAAQ,MAAMC,aAAa;UAAEN;UAAOC;UAAMC;UAAUC;QAAmB,CAAA;MAAG;IACpF;EACF,CAAA;EACAR,eAAe;IACbC,QAAQC,aAAaU;IACrBR,SAAS,CAAC,EAAES,QAAQC,SAASC,aAAY,GAAIC,SAAAA;AAC3CC,gBAAUJ,OAAOK,UAAQ,QAAA;;;;;;;;;AACzBD,gBAAUJ,OAAOK,SAASC,QAAQC,MAAMb,UAAAA,QAAAA;;;;;;;;;AAExC,YAAMc,SACJR,OAAOK,SAASC,UAChBG,SAAST,MAAAA,GAASU,GAAGC,eAAeC,UAAUZ,OAAOK,SAASC,OAAOC,MAAMb,QAAQ;AACrFU,gBAAUI,QAAAA,QAAAA;;;;;;;;;AACVJ,gBAAUJ,OAAOK,SAASC,QAAM,QAAA;;;;;;;;;AAChC,YAAMO,aAAa,IAAIC,eAAeN,OAAOO,YAAYf,OAAOK,SAASC,MAAM;AAE/E,UAAI,CAACH,MAAM;AACT,cAAM,EAAEa,SAASC,MAAK,IAAKJ,WAAWK,sBAAsBjB,OAAAA;AAC5D,eAAO;UACLkB,UAAU;YACRC,SAAS;cAAC;cAA4B;gBAAEC,IAAIC;cAAc;;YAC1D1B,MAAM;cAAEM,cAAc;gBAAE,GAAGc;gBAASC;cAAM;YAAE;UAC9C;QACF;MACF,WAAWd,QAAQD,cAAc;AAC/B,cAAM,EAAEqB,OAAOC,OAAOP,MAAK,IAAKf;AAChCW,mBAAWY,mBAAmB;UAAEF;UAAOC;QAAM,GAAGP,KAAAA;MAClD;IACF;EACF,CAAA;EACA9B,eAAe;IACbC,QAAQC,aAAaqC;IACrBnC,SAAS,CAAC,EAAEoC,KAAI,GAAIxB,SAAAA;AAClB,YAAMX,QAAQiB,SAASkB,IAAAA;AACvBvB,gBAAUZ,OAAAA,QAAAA;;;;;;;;;AAEV,UAAI,CAACW,MAAM;AACTX,cAAMkB,GAAGkB,OAAOD,IAAAA;AAChB,eAAO;UACLR,UAAU;YACRC,SAAS;cAAC;cAAsB;gBAAEC,IAAIC;cAAc;;YACpD1B,MAAM;cAAE+B;YAAK;UACf;QACF;MACF,OAAO;AACLnC,cAAMkB,GAAGmB,IAAIF,IAAAA;MACf;IACF;EACF,CAAA;CACD;",
|
|
6
|
-
"names": ["contributes", "Capabilities", "createResolver", "invariant", "getSpace", "ViewProjection", "contributes", "Capabilities", "IntentResolver", "createResolver", "intent", "KanbanAction", "Create", "resolve", "space", "name", "typename", "initialPivotColumn", "data", "object", "createKanban", "DeleteCardField", "kanban", "fieldId", "deletionData", "undo", "invariant", "cardView", "target", "query", "schema", "getSpace", "db", "schemaRegistry", "getSchema", "projection", "ViewProjection", "jsonSchema", "deleted", "index", "deleteFieldProjection", "undoable", "message", "ns", "KANBAN_PLUGIN", "field", "props", "setFieldProjection", "DeleteCard", "card", "remove", "add"]
|
|
7
|
-
}
|