@dxos/plugin-kanban 0.8.2-staging.7ac8446 → 0.8.2
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
package/dist/lib/browser/{artifact-definition-SVNHDJQT.mjs → artifact-definition-7AVKC5KJ.mjs}
RENAMED
|
@@ -1,20 +1,21 @@
|
|
|
1
1
|
import {
|
|
2
2
|
KanbanAction,
|
|
3
3
|
meta
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-NJ6WHYLY.mjs";
|
|
5
5
|
|
|
6
6
|
// packages/plugins/plugin-kanban/src/capabilities/artifact-definition.ts
|
|
7
|
-
import { pipe } from "effect";
|
|
7
|
+
import { Schema, pipe } from "effect";
|
|
8
|
+
import { createTool, ToolResult } from "@dxos/ai";
|
|
8
9
|
import { Capabilities, chain, contributes, createIntent } from "@dxos/app-framework";
|
|
9
|
-
import { defineArtifact
|
|
10
|
+
import { defineArtifact } from "@dxos/artifact";
|
|
10
11
|
import { createArtifactElement } from "@dxos/assistant";
|
|
11
|
-
import { isInstanceOf
|
|
12
|
+
import { isInstanceOf } from "@dxos/echo-schema";
|
|
12
13
|
import { invariant } from "@dxos/invariant";
|
|
13
14
|
import { SpaceAction } from "@dxos/plugin-space/types";
|
|
14
15
|
import { Filter, fullyQualifiedId } from "@dxos/react-client/echo";
|
|
15
16
|
import { KanbanType } from "@dxos/react-ui-kanban";
|
|
16
17
|
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/plugin-kanban/src/capabilities/artifact-definition.ts";
|
|
17
|
-
var QualifiedId =
|
|
18
|
+
var QualifiedId = Schema.String.annotations({
|
|
18
19
|
description: "The fully qualified ID of the kanban `spaceID:objectID`"
|
|
19
20
|
});
|
|
20
21
|
var artifact_definition_default = () => {
|
|
@@ -28,24 +29,24 @@ var artifact_definition_default = () => {
|
|
|
28
29
|
`,
|
|
29
30
|
schema: KanbanType,
|
|
30
31
|
tools: [
|
|
31
|
-
|
|
32
|
+
createTool(meta.id, {
|
|
32
33
|
name: "create",
|
|
33
34
|
description: `
|
|
34
35
|
Create a new kanban board using an existing schema.
|
|
35
36
|
Use schema_create first to create a schema, or schema_list to choose an existing one.`,
|
|
36
37
|
caption: "Creating kanban board...",
|
|
37
|
-
schema:
|
|
38
|
-
typename:
|
|
38
|
+
schema: Schema.Struct({
|
|
39
|
+
typename: Schema.String.annotations({
|
|
39
40
|
description: "The fully qualified typename of the schema to use for the kanban cards."
|
|
40
41
|
}),
|
|
41
|
-
pivotColumn:
|
|
42
|
+
pivotColumn: Schema.optional(Schema.String).annotations({
|
|
42
43
|
description: "Optional field name to use as the column pivot."
|
|
43
44
|
})
|
|
44
45
|
}),
|
|
45
46
|
execute: async ({ typename, pivotColumn }, { extensions }) => {
|
|
46
47
|
invariant(extensions?.space, "No space", {
|
|
47
48
|
F: __dxlog_file,
|
|
48
|
-
L:
|
|
49
|
+
L: 57,
|
|
49
50
|
S: void 0,
|
|
50
51
|
A: [
|
|
51
52
|
"extensions?.space",
|
|
@@ -54,7 +55,7 @@ var artifact_definition_default = () => {
|
|
|
54
55
|
});
|
|
55
56
|
invariant(extensions?.dispatch, "No intent dispatcher", {
|
|
56
57
|
F: __dxlog_file,
|
|
57
|
-
L:
|
|
58
|
+
L: 58,
|
|
58
59
|
S: void 0,
|
|
59
60
|
A: [
|
|
60
61
|
"extensions?.dispatch",
|
|
@@ -81,15 +82,15 @@ var artifact_definition_default = () => {
|
|
|
81
82
|
return ToolResult.Success(createArtifactElement(data.id));
|
|
82
83
|
}
|
|
83
84
|
}),
|
|
84
|
-
|
|
85
|
+
createTool(meta.id, {
|
|
85
86
|
name: "list",
|
|
86
87
|
description: "List all kanban boards in the current space.",
|
|
87
88
|
caption: "Listing kanban boards...",
|
|
88
|
-
schema:
|
|
89
|
+
schema: Schema.Struct({}),
|
|
89
90
|
execute: async (_input, { extensions }) => {
|
|
90
91
|
invariant(extensions?.space, "No space", {
|
|
91
92
|
F: __dxlog_file,
|
|
92
|
-
L:
|
|
93
|
+
L: 89,
|
|
93
94
|
S: void 0,
|
|
94
95
|
A: [
|
|
95
96
|
"extensions?.space",
|
|
@@ -97,7 +98,7 @@ var artifact_definition_default = () => {
|
|
|
97
98
|
]
|
|
98
99
|
});
|
|
99
100
|
const space = extensions.space;
|
|
100
|
-
const { objects: boards } = await space.db.query(Filter.
|
|
101
|
+
const { objects: boards } = await space.db.query(Filter.type(KanbanType)).run();
|
|
101
102
|
const boardInfo = await Promise.all(boards.map(async (board) => {
|
|
102
103
|
const view = await board.cardView?.load();
|
|
103
104
|
return {
|
|
@@ -108,17 +109,17 @@ var artifact_definition_default = () => {
|
|
|
108
109
|
return ToolResult.Success(boardInfo);
|
|
109
110
|
}
|
|
110
111
|
}),
|
|
111
|
-
|
|
112
|
+
createTool(meta.id, {
|
|
112
113
|
name: "inspect",
|
|
113
114
|
description: "Get details about a specific kanban board.",
|
|
114
115
|
caption: "Inspecting kanban board...",
|
|
115
|
-
schema:
|
|
116
|
+
schema: Schema.Struct({
|
|
116
117
|
id: QualifiedId
|
|
117
118
|
}),
|
|
118
119
|
execute: async ({ id }, { extensions }) => {
|
|
119
120
|
invariant(extensions?.space, "No space", {
|
|
120
121
|
F: __dxlog_file,
|
|
121
|
-
L:
|
|
122
|
+
L: 112,
|
|
122
123
|
S: void 0,
|
|
123
124
|
A: [
|
|
124
125
|
"extensions?.space",
|
|
@@ -126,11 +127,11 @@ var artifact_definition_default = () => {
|
|
|
126
127
|
]
|
|
127
128
|
});
|
|
128
129
|
const space = extensions.space;
|
|
129
|
-
const { objects: boards } = await space.db.query(Filter.
|
|
130
|
+
const { objects: boards } = await space.db.query(Filter.type(KanbanType)).run();
|
|
130
131
|
const board = boards.find((board2) => fullyQualifiedId(board2) === id);
|
|
131
132
|
invariant(isInstanceOf(KanbanType, board), void 0, {
|
|
132
133
|
F: __dxlog_file,
|
|
133
|
-
L:
|
|
134
|
+
L: 116,
|
|
134
135
|
S: void 0,
|
|
135
136
|
A: [
|
|
136
137
|
"isInstanceOf(KanbanType, board)",
|
|
@@ -140,7 +141,7 @@ var artifact_definition_default = () => {
|
|
|
140
141
|
const view = await board.cardView?.load();
|
|
141
142
|
invariant(view, void 0, {
|
|
142
143
|
F: __dxlog_file,
|
|
143
|
-
L:
|
|
144
|
+
L: 119,
|
|
144
145
|
S: void 0,
|
|
145
146
|
A: [
|
|
146
147
|
"view",
|
|
@@ -153,7 +154,7 @@ var artifact_definition_default = () => {
|
|
|
153
154
|
}).firstOrUndefined();
|
|
154
155
|
invariant(schema, void 0, {
|
|
155
156
|
F: __dxlog_file,
|
|
156
|
-
L:
|
|
157
|
+
L: 123,
|
|
157
158
|
S: void 0,
|
|
158
159
|
A: [
|
|
159
160
|
"schema",
|
|
@@ -174,4 +175,4 @@ var artifact_definition_default = () => {
|
|
|
174
175
|
export {
|
|
175
176
|
artifact_definition_default as default
|
|
176
177
|
};
|
|
177
|
-
//# sourceMappingURL=artifact-definition-
|
|
178
|
+
//# sourceMappingURL=artifact-definition-7AVKC5KJ.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
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 { defineArtifact } 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 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: boards } = await space.db.query(Filter.type(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 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 { objects: boards } = await space.db.query(Filter.type(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", "createTool", "ToolResult", "Capabilities", "chain", "contributes", "createIntent", "defineArtifact", "createArtifactElement", "isInstanceOf", "invariant", "SpaceAction", "Filter", "fullyQualifiedId", "KanbanType", "QualifiedId", "Schema", "String", "annotations", "description", "definition", "defineArtifact", "id", "meta", "name", "instructions", "schema", "KanbanType", "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", "boards", "Filter", "type", "run", "boardInfo", "Promise", "all", "map", "board", "view", "cardView", "load", "fullyQualifiedId", "find", "isInstanceOf", "columnField", "columnFieldId", "viewFields", "fields", "contributes", "Capabilities", "ArtifactDefinition"]
|
|
7
|
+
}
|
|
@@ -1,9 +1,7 @@
|
|
|
1
1
|
// packages/plugins/plugin-kanban/src/types.ts
|
|
2
|
-
import {
|
|
3
|
-
import { S } from "@dxos/echo-schema";
|
|
2
|
+
import { Schema } from "effect";
|
|
4
3
|
import { SpaceSchema } from "@dxos/react-client/echo";
|
|
5
4
|
import { KanbanType } from "@dxos/react-ui-kanban";
|
|
6
|
-
import { initializeKanban } from "@dxos/react-ui-kanban/testing";
|
|
7
5
|
import { FieldSchema } from "@dxos/schema";
|
|
8
6
|
|
|
9
7
|
// packages/plugins/plugin-kanban/src/meta.ts
|
|
@@ -13,10 +11,7 @@ var meta = {
|
|
|
13
11
|
name: "Kanban",
|
|
14
12
|
description: "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.",
|
|
15
13
|
icon: "ph--kanban--regular",
|
|
16
|
-
source: "https://github.com/dxos/dxos/tree/main/packages/plugins/
|
|
17
|
-
tags: [
|
|
18
|
-
"experimental"
|
|
19
|
-
],
|
|
14
|
+
source: "https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-kanban",
|
|
20
15
|
screenshots: [
|
|
21
16
|
"https://dxos.network/plugin-details-kanban-dark.png"
|
|
22
17
|
]
|
|
@@ -25,66 +20,57 @@ var meta = {
|
|
|
25
20
|
// packages/plugins/plugin-kanban/src/types.ts
|
|
26
21
|
var TypenameAnnotationId = Symbol.for("@dxos/plugin-kanban/annotation/Typename");
|
|
27
22
|
var PivotColumnAnnotationId = Symbol.for("@dxos/plugin-kanban/annotation/PivotColumn");
|
|
28
|
-
var CreateKanbanSchema =
|
|
29
|
-
name:
|
|
30
|
-
typename:
|
|
23
|
+
var CreateKanbanSchema = Schema.Struct({
|
|
24
|
+
name: Schema.optional(Schema.String),
|
|
25
|
+
typename: Schema.optional(Schema.String.annotations({
|
|
31
26
|
[TypenameAnnotationId]: true,
|
|
32
|
-
|
|
27
|
+
title: "Select card schema (leave empty to start fresh)"
|
|
33
28
|
})),
|
|
34
|
-
initialPivotColumn:
|
|
29
|
+
initialPivotColumn: Schema.optional(Schema.String.annotations({
|
|
35
30
|
[PivotColumnAnnotationId]: true,
|
|
36
|
-
|
|
31
|
+
title: "Pivot column"
|
|
37
32
|
}))
|
|
38
33
|
});
|
|
39
|
-
var KanbanAction;
|
|
40
34
|
(function(KanbanAction2) {
|
|
41
35
|
const KANBAN_ACTION = `${KANBAN_PLUGIN}/action`;
|
|
42
|
-
class Create extends
|
|
43
|
-
input:
|
|
36
|
+
class Create extends Schema.TaggedClass()(`${KANBAN_ACTION}/create`, {
|
|
37
|
+
input: Schema.extend(Schema.Struct({
|
|
44
38
|
space: SpaceSchema
|
|
45
39
|
}), CreateKanbanSchema),
|
|
46
|
-
output:
|
|
40
|
+
output: Schema.Struct({
|
|
47
41
|
object: KanbanType
|
|
48
42
|
})
|
|
49
43
|
}) {
|
|
50
44
|
}
|
|
51
45
|
KanbanAction2.Create = Create;
|
|
52
|
-
class DeleteCardField extends
|
|
53
|
-
input:
|
|
46
|
+
class DeleteCardField extends Schema.TaggedClass()(`${KANBAN_ACTION}/delete-card-field`, {
|
|
47
|
+
input: Schema.Struct({
|
|
54
48
|
kanban: KanbanType,
|
|
55
|
-
fieldId:
|
|
49
|
+
fieldId: Schema.String,
|
|
56
50
|
// TODO(wittjosiah): Separate fields for undo data?
|
|
57
|
-
deletionData:
|
|
51
|
+
deletionData: Schema.optional(Schema.Struct({
|
|
58
52
|
field: FieldSchema,
|
|
59
53
|
// TODO(wittjosiah): This creates a type error.
|
|
60
54
|
// props: PropertySchema,
|
|
61
|
-
props:
|
|
62
|
-
index:
|
|
55
|
+
props: Schema.Any,
|
|
56
|
+
index: Schema.Number
|
|
63
57
|
}))
|
|
64
58
|
}),
|
|
65
|
-
output:
|
|
59
|
+
output: Schema.Void
|
|
66
60
|
}) {
|
|
67
61
|
}
|
|
68
62
|
KanbanAction2.DeleteCardField = DeleteCardField;
|
|
69
|
-
class DeleteCard extends
|
|
70
|
-
input:
|
|
71
|
-
card:
|
|
63
|
+
class DeleteCard extends Schema.TaggedClass()(`${KANBAN_ACTION}/delete-card`, {
|
|
64
|
+
input: Schema.Struct({
|
|
65
|
+
card: Schema.Any
|
|
72
66
|
}),
|
|
73
|
-
output:
|
|
67
|
+
output: Schema.Void
|
|
74
68
|
}) {
|
|
75
69
|
}
|
|
76
70
|
KanbanAction2.DeleteCard = DeleteCard;
|
|
77
71
|
})(KanbanAction || (KanbanAction = {}));
|
|
78
72
|
var isKanban = (object) => object != null && object instanceof KanbanType;
|
|
79
|
-
var
|
|
80
|
-
const { kanban } = await initializeKanban({
|
|
81
|
-
space,
|
|
82
|
-
name,
|
|
83
|
-
typename,
|
|
84
|
-
initialPivotColumn
|
|
85
|
-
});
|
|
86
|
-
return kanban;
|
|
87
|
-
};
|
|
73
|
+
var KanbanAction;
|
|
88
74
|
|
|
89
75
|
export {
|
|
90
76
|
KANBAN_PLUGIN,
|
|
@@ -92,8 +78,7 @@ export {
|
|
|
92
78
|
TypenameAnnotationId,
|
|
93
79
|
PivotColumnAnnotationId,
|
|
94
80
|
CreateKanbanSchema,
|
|
95
|
-
KanbanAction,
|
|
96
81
|
isKanban,
|
|
97
|
-
|
|
82
|
+
KanbanAction
|
|
98
83
|
};
|
|
99
|
-
//# sourceMappingURL=chunk-
|
|
84
|
+
//# sourceMappingURL=chunk-NJ6WHYLY.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/types.ts", "../../../src/meta.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } 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 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 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/plugin-kanban',\n screenshots: ['https://dxos.network/plugin-details-kanban-dark.png'],\n};\n"],
|
|
5
|
+
"mappings": ";AAIA,SAASA,cAAc;AAEvB,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,aAAa;IAAC;;AAChB;;;ADMO,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;IACxBY,OAAO;EACT,CAAA,CAAA;EAEFC,oBAAoBR,OAAOG,SACzBH,OAAOI,OAAOE,YAAY;IACxB,CAACR,uBAAAA,GAA0B;IAC3BS,OAAO;EACT,CAAA,CAAA;AAEJ,CAAA;UAIiBE,eAAAA;AACf,QAAMC,gBAAgB,GAAGC,aAAAA;EAElB,MAAMC,eAAeZ,OAAOa,YAAW,EAAW,GAAGH,aAAAA,WAAwB;IAClFI,OAAOd,OAAOe,OAAOf,OAAOC,OAAO;MAAEe,OAAOC;IAAY,CAAA,GAAIlB,kBAAAA;IAC5DmB,QAAQlB,OAAOC,OAAO;MACpBkB,QAAQC;IACV,CAAA;EACF,CAAA,EAAA;EAAI;gBALSR,SAAAA;EAON,MAAMS,wBAAwBrB,OAAOa,YAAW,EAAoB,GAAGH,aAAAA,sBAAmC;IAC/GI,OAAOd,OAAOC,OAAO;MACnBqB,QAAQF;MACRG,SAASvB,OAAOI;;MAEhBoB,cAAcxB,OAAOG,SACnBH,OAAOC,OAAO;QACZwB,OAAOC;;;QAGPC,OAAO3B,OAAO4B;QACdC,OAAO7B,OAAO8B;MAChB,CAAA,CAAA;IAEJ,CAAA;IACAZ,QAAQlB,OAAO+B;EACjB,CAAA,EAAA;EAAI;gBAhBSV,kBAAAA;EAkBN,MAAMW,mBAAmBhC,OAAOa,YAAW,EAAe,GAAGH,aAAAA,gBAA6B;IAC/FI,OAAOd,OAAOC,OAAO;MACnBgC,MAAMjC,OAAO4B;IACf,CAAA;IACAV,QAAQlB,OAAO+B;EACjB,CAAA,EAAA;EAAI;gBALSC,aAAAA;AAMf,GAlCiBvB,iBAAAA,eAAAA,CAAAA,EAAAA;AAoDV,IAAMyB,WAAW,CAACf,WAA0CA,UAAU,QAAQA,kBAAkBC;;",
|
|
6
|
+
"names": ["Schema", "SpaceSchema", "KanbanType", "FieldSchema", "KANBAN_PLUGIN", "meta", "id", "name", "description", "icon", "source", "screenshots", "TypenameAnnotationId", "Symbol", "for", "PivotColumnAnnotationId", "CreateKanbanSchema", "Schema", "Struct", "name", "optional", "String", "typename", "annotations", "title", "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
|
+
}
|
|
@@ -3,7 +3,7 @@ import {
|
|
|
3
3
|
KANBAN_PLUGIN,
|
|
4
4
|
KanbanAction,
|
|
5
5
|
meta
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-NJ6WHYLY.mjs";
|
|
7
7
|
|
|
8
8
|
// packages/plugins/plugin-kanban/src/KanbanPlugin.tsx
|
|
9
9
|
import { createIntent, defineModule, contributes, Capabilities, Events, definePlugin } from "@dxos/app-framework";
|
|
@@ -14,9 +14,9 @@ import { KanbanType as KanbanType2, translations as kanbanTranslations } from "@
|
|
|
14
14
|
|
|
15
15
|
// packages/plugins/plugin-kanban/src/capabilities/index.ts
|
|
16
16
|
import { lazy } from "@dxos/app-framework";
|
|
17
|
-
var ArtifactDefinition = lazy(() => import("./artifact-definition-
|
|
18
|
-
var IntentResolver = lazy(() => import("./intent-resolver-
|
|
19
|
-
var ReactSurface = lazy(() => import("./react-surface-
|
|
17
|
+
var ArtifactDefinition = lazy(() => import("./artifact-definition-7AVKC5KJ.mjs"));
|
|
18
|
+
var IntentResolver = lazy(() => import("./intent-resolver-2R6I36UA.mjs"));
|
|
19
|
+
var ReactSurface = lazy(() => import("./react-surface-W43CBHJ2.mjs"));
|
|
20
20
|
|
|
21
21
|
// packages/plugins/plugin-kanban/src/translations.ts
|
|
22
22
|
import { KanbanType } from "@dxos/react-ui-kanban";
|
|
@@ -0,0 +1,297 @@
|
|
|
1
|
+
import {
|
|
2
|
+
KANBAN_PLUGIN,
|
|
3
|
+
KanbanAction
|
|
4
|
+
} from "./chunk-NJ6WHYLY.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 } 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
|
+
title: "Title"
|
|
47
|
+
}),
|
|
48
|
+
description: Schema.optional(Schema.String).annotations({
|
|
49
|
+
title: "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.getCapability(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-2R6I36UA.mjs.map
|