@dxos/plugin-kanban 0.7.5-main.9cb18ac → 0.7.5-main.9d2a38b
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/{chunk-JZBAL6SW.mjs → chunk-L4PZ5BVV.mjs} +18 -5
- package/dist/lib/browser/chunk-L4PZ5BVV.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +55 -243
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/intent-resolver-ILMGO3TT.mjs +70 -0
- package/dist/lib/browser/intent-resolver-ILMGO3TT.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-surface-KCOBVPKL.mjs +180 -0
- package/dist/lib/browser/react-surface-KCOBVPKL.mjs.map +7 -0
- package/dist/lib/browser/types.mjs +1 -2
- package/dist/lib/node/{chunk-BE2FRW7E.cjs → chunk-QCB2U2J2.cjs} +22 -8
- package/dist/lib/node/chunk-QCB2U2J2.cjs.map +7 -0
- package/dist/lib/node/index.cjs +56 -235
- package/dist/lib/node/index.cjs.map +4 -4
- package/dist/lib/node/intent-resolver-6QZ6AMZF.cjs +84 -0
- package/dist/lib/node/intent-resolver-6QZ6AMZF.cjs.map +7 -0
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/react-surface-MOZ2OTXW.cjs +198 -0
- package/dist/lib/node/react-surface-MOZ2OTXW.cjs.map +7 -0
- package/dist/lib/node/types.cjs +4 -5
- package/dist/lib/node/types.cjs.map +2 -2
- package/dist/lib/node-esm/{chunk-L7JM7LGJ.mjs → chunk-PNSRVZBP.mjs} +18 -4
- package/dist/lib/node-esm/chunk-PNSRVZBP.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +55 -243
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/intent-resolver-LRZVOK2C.mjs +71 -0
- package/dist/lib/node-esm/intent-resolver-LRZVOK2C.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/react-surface-HNVSKYHF.mjs +181 -0
- package/dist/lib/node-esm/react-surface-HNVSKYHF.mjs.map +7 -0
- package/dist/lib/node-esm/types.mjs +1 -2
- package/dist/types/src/KanbanPlugin.d.ts +1 -3
- package/dist/types/src/KanbanPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +3 -0
- package/dist/types/src/capabilities/index.d.ts.map +1 -0
- package/dist/types/src/capabilities/intent-resolver.d.ts +4 -0
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -0
- package/dist/types/src/capabilities/react-surface.d.ts +4 -0
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
- package/dist/types/src/components/KanbanViewEditor.d.ts +2 -2
- package/dist/types/src/components/KanbanViewEditor.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +1 -0
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +1 -2
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +1 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/types.d.ts +10 -4
- package/dist/types/src/types.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +21 -29
- package/src/KanbanPlugin.tsx +48 -72
- package/src/capabilities/index.ts +8 -0
- package/src/capabilities/intent-resolver.ts +39 -0
- package/src/capabilities/react-surface.tsx +28 -0
- package/src/components/KanbanViewEditor.tsx +21 -5
- package/src/components/index.ts +1 -0
- package/src/index.ts +1 -4
- package/src/meta.ts +1 -1
- package/src/types.ts +0 -13
- package/dist/lib/browser/chunk-JZBAL6SW.mjs.map +0 -7
- package/dist/lib/browser/chunk-LG4OMN5S.mjs +0 -18
- package/dist/lib/browser/chunk-LG4OMN5S.mjs.map +0 -7
- package/dist/lib/browser/meta.mjs +0 -9
- package/dist/lib/browser/meta.mjs.map +0 -7
- package/dist/lib/node/chunk-BE2FRW7E.cjs.map +0 -7
- package/dist/lib/node/chunk-MBAGHRFM.cjs +0 -41
- package/dist/lib/node/chunk-MBAGHRFM.cjs.map +0 -7
- package/dist/lib/node/meta.cjs +0 -30
- package/dist/lib/node/meta.cjs.map +0 -7
- package/dist/lib/node-esm/chunk-L7JM7LGJ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-OTZHYV3S.mjs +0 -20
- package/dist/lib/node-esm/chunk-OTZHYV3S.mjs.map +0 -7
- package/dist/lib/node-esm/meta.mjs +0 -10
- package/dist/lib/node-esm/meta.mjs.map +0 -7
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import {
|
|
2
|
+
KANBAN_PLUGIN,
|
|
3
|
+
KanbanAction,
|
|
4
|
+
isKanban
|
|
5
|
+
} from "./chunk-L4PZ5BVV.mjs";
|
|
6
|
+
|
|
7
|
+
// packages/plugins/experimental/plugin-kanban/src/capabilities/react-surface.tsx
|
|
8
|
+
import React3 from "react";
|
|
9
|
+
import { Capabilities, contributes, createSurface } from "@dxos/app-framework";
|
|
10
|
+
|
|
11
|
+
// packages/plugins/experimental/plugin-kanban/src/components/KanbanContainer.tsx
|
|
12
|
+
import React, { useCallback, useEffect, useState } from "react";
|
|
13
|
+
import { invariant } from "@dxos/invariant";
|
|
14
|
+
import { useGlobalFilteredObjects } from "@dxos/plugin-search";
|
|
15
|
+
import { Filter, useQuery, getSpace, create } from "@dxos/react-client/echo";
|
|
16
|
+
import { useKanbanModel, Kanban } from "@dxos/react-ui-kanban";
|
|
17
|
+
import { StackItem } from "@dxos/react-ui-stack";
|
|
18
|
+
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/experimental/plugin-kanban/src/components/KanbanContainer.tsx";
|
|
19
|
+
var KanbanContainer = ({ kanban }) => {
|
|
20
|
+
const [cardSchema, setCardSchema] = useState();
|
|
21
|
+
const space = getSpace(kanban);
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
if (kanban.cardView && space) {
|
|
24
|
+
setCardSchema(space.db.schemaRegistry.getSchema(kanban.cardView.target.query.type));
|
|
25
|
+
}
|
|
26
|
+
}, [
|
|
27
|
+
kanban.cardView,
|
|
28
|
+
space
|
|
29
|
+
]);
|
|
30
|
+
const objects = useQuery(space, cardSchema ? Filter.schema(cardSchema) : Filter.nothing());
|
|
31
|
+
const filteredObjects = useGlobalFilteredObjects(objects);
|
|
32
|
+
const model = useKanbanModel({
|
|
33
|
+
kanban,
|
|
34
|
+
cardSchema,
|
|
35
|
+
items: filteredObjects
|
|
36
|
+
});
|
|
37
|
+
const handleAddColumn = useCallback((columnValue) => model?.addEmptyColumn(columnValue), [
|
|
38
|
+
model
|
|
39
|
+
]);
|
|
40
|
+
const handleAddCard = useCallback((columnValue) => {
|
|
41
|
+
if (space && cardSchema) {
|
|
42
|
+
space.db.add(create(cardSchema, {
|
|
43
|
+
title: "",
|
|
44
|
+
description: "",
|
|
45
|
+
state: columnValue
|
|
46
|
+
}));
|
|
47
|
+
}
|
|
48
|
+
}, [
|
|
49
|
+
space,
|
|
50
|
+
cardSchema
|
|
51
|
+
]);
|
|
52
|
+
const handleRemoveCard = useCallback((card) => {
|
|
53
|
+
invariant(space, void 0, {
|
|
54
|
+
F: __dxlog_file,
|
|
55
|
+
L: 51,
|
|
56
|
+
S: void 0,
|
|
57
|
+
A: [
|
|
58
|
+
"space",
|
|
59
|
+
""
|
|
60
|
+
]
|
|
61
|
+
});
|
|
62
|
+
space.db.remove(card);
|
|
63
|
+
}, [
|
|
64
|
+
space
|
|
65
|
+
]);
|
|
66
|
+
const handleRemoveEmptyColumn = useCallback((columnValue) => {
|
|
67
|
+
model?.removeColumnFromArrangement(columnValue);
|
|
68
|
+
}, [
|
|
69
|
+
model
|
|
70
|
+
]);
|
|
71
|
+
return /* @__PURE__ */ React.createElement(StackItem.Content, {
|
|
72
|
+
toolbar: false
|
|
73
|
+
}, model ? /* @__PURE__ */ React.createElement(Kanban, {
|
|
74
|
+
model,
|
|
75
|
+
onAddCard: handleAddCard,
|
|
76
|
+
onAddColumn: handleAddColumn,
|
|
77
|
+
onRemoveCard: handleRemoveCard,
|
|
78
|
+
onRemoveEmptyColumn: handleRemoveEmptyColumn
|
|
79
|
+
}) : /* @__PURE__ */ React.createElement("span", null, "Loading"));
|
|
80
|
+
};
|
|
81
|
+
|
|
82
|
+
// packages/plugins/experimental/plugin-kanban/src/components/KanbanViewEditor.tsx
|
|
83
|
+
import React2, { useCallback as useCallback2, useEffect as useEffect2, useMemo, useState as useState2 } from "react";
|
|
84
|
+
import { createIntent, useIntentDispatcher } from "@dxos/app-framework";
|
|
85
|
+
import { Filter as Filter2, getSpace as getSpace2, useQuery as useQuery2 } from "@dxos/react-client/echo";
|
|
86
|
+
import { ViewEditor, Form } from "@dxos/react-ui-form";
|
|
87
|
+
import { KanbanPropsSchema } from "@dxos/react-ui-kanban";
|
|
88
|
+
import { ViewType } from "@dxos/schema";
|
|
89
|
+
var KanbanViewEditor = ({ kanban }) => {
|
|
90
|
+
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
91
|
+
const space = getSpace2(kanban);
|
|
92
|
+
const [schema, setSchema] = useState2(space && kanban?.cardView?.target?.query?.type ? space.db.schemaRegistry.getSchema(kanban.cardView.target.query.type) : void 0);
|
|
93
|
+
const views = useQuery2(space, Filter2.schema(ViewType));
|
|
94
|
+
const currentTypename = useMemo(() => kanban?.cardView?.target?.query?.type, [
|
|
95
|
+
kanban?.cardView?.target?.query?.type
|
|
96
|
+
]);
|
|
97
|
+
const updateViewTypename = useCallback2((newTypename) => {
|
|
98
|
+
if (!schema) {
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
const matchingViews = views.filter((view) => view.query.type === currentTypename);
|
|
102
|
+
for (const view of matchingViews) {
|
|
103
|
+
view.query.type = newTypename;
|
|
104
|
+
}
|
|
105
|
+
schema.updateTypename(newTypename);
|
|
106
|
+
}, [
|
|
107
|
+
views,
|
|
108
|
+
schema
|
|
109
|
+
]);
|
|
110
|
+
useEffect2(() => {
|
|
111
|
+
if (space && kanban?.cardView?.target?.query?.type) {
|
|
112
|
+
const unsubscribe = space.db.schemaRegistry.query({
|
|
113
|
+
typename: kanban?.cardView?.target?.query?.type
|
|
114
|
+
}).subscribe((query) => {
|
|
115
|
+
const [schema2] = query.results;
|
|
116
|
+
if (schema2) {
|
|
117
|
+
setSchema(schema2);
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
return unsubscribe;
|
|
121
|
+
}
|
|
122
|
+
}, [
|
|
123
|
+
space,
|
|
124
|
+
kanban?.cardView?.target?.query?.type
|
|
125
|
+
]);
|
|
126
|
+
const handleDelete = useCallback2((fieldId) => dispatch?.(createIntent(KanbanAction.DeleteCardField, {
|
|
127
|
+
kanban,
|
|
128
|
+
fieldId
|
|
129
|
+
})), [
|
|
130
|
+
dispatch,
|
|
131
|
+
kanban
|
|
132
|
+
]);
|
|
133
|
+
if (!space || !schema || !kanban.cardView?.target) {
|
|
134
|
+
return null;
|
|
135
|
+
}
|
|
136
|
+
return /* @__PURE__ */ React2.createElement(React2.Fragment, null, /* @__PURE__ */ React2.createElement(Form, {
|
|
137
|
+
schema: KanbanPropsSchema,
|
|
138
|
+
values: {
|
|
139
|
+
columnField: kanban.columnField
|
|
140
|
+
},
|
|
141
|
+
onSave: ({ columnField }) => {
|
|
142
|
+
kanban.columnField = columnField;
|
|
143
|
+
kanban.arrangement = void 0;
|
|
144
|
+
}
|
|
145
|
+
}), /* @__PURE__ */ React2.createElement(ViewEditor, {
|
|
146
|
+
registry: space.db.schemaRegistry,
|
|
147
|
+
schema,
|
|
148
|
+
view: kanban.cardView.target,
|
|
149
|
+
onTypenameChanged: updateViewTypename,
|
|
150
|
+
onDelete: handleDelete
|
|
151
|
+
}));
|
|
152
|
+
};
|
|
153
|
+
|
|
154
|
+
// packages/plugins/experimental/plugin-kanban/src/capabilities/react-surface.tsx
|
|
155
|
+
var react_surface_default = () => contributes(Capabilities.ReactSurface, [
|
|
156
|
+
createSurface({
|
|
157
|
+
id: `${KANBAN_PLUGIN}/kanban`,
|
|
158
|
+
role: [
|
|
159
|
+
"article",
|
|
160
|
+
"section"
|
|
161
|
+
],
|
|
162
|
+
filter: (data) => isKanban(data.subject),
|
|
163
|
+
component: ({ data, role }) => /* @__PURE__ */ React3.createElement(KanbanContainer, {
|
|
164
|
+
kanban: data.subject,
|
|
165
|
+
role
|
|
166
|
+
})
|
|
167
|
+
}),
|
|
168
|
+
createSurface({
|
|
169
|
+
id: `${KANBAN_PLUGIN}/settings`,
|
|
170
|
+
role: "complementary--settings",
|
|
171
|
+
filter: (data) => isKanban(data.subject),
|
|
172
|
+
component: ({ data }) => /* @__PURE__ */ React3.createElement(KanbanViewEditor, {
|
|
173
|
+
kanban: data.subject
|
|
174
|
+
})
|
|
175
|
+
})
|
|
176
|
+
]);
|
|
177
|
+
export {
|
|
178
|
+
react_surface_default as default
|
|
179
|
+
};
|
|
180
|
+
//# sourceMappingURL=react-surface-KCOBVPKL.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/capabilities/react-surface.tsx", "../../../src/components/KanbanContainer.tsx", "../../../src/components/KanbanViewEditor.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Capabilities, contributes, createSurface } from '@dxos/app-framework';\nimport { type KanbanType } from '@dxos/react-ui-kanban';\n\nimport { KanbanContainer, KanbanViewEditor } from '../components';\nimport { KANBAN_PLUGIN } from '../meta';\nimport { isKanban } from '../types';\n\nexport default () =>\n contributes(Capabilities.ReactSurface, [\n createSurface({\n id: `${KANBAN_PLUGIN}/kanban`,\n role: ['article', 'section'],\n filter: (data): data is { subject: KanbanType } => isKanban(data.subject),\n component: ({ data, role }) => <KanbanContainer kanban={data.subject} role={role} />,\n }),\n createSurface({\n id: `${KANBAN_PLUGIN}/settings`,\n role: 'complementary--settings',\n filter: (data): data is { subject: KanbanType } => isKanban(data.subject),\n component: ({ data }) => <KanbanViewEditor kanban={data.subject} />,\n }),\n ]);\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useCallback, useEffect, useState } from 'react';\n\nimport { type EchoSchema } from '@dxos/echo-schema';\nimport { invariant } from '@dxos/invariant';\nimport { useGlobalFilteredObjects } from '@dxos/plugin-search';\nimport { Filter, useQuery, getSpace, create } from '@dxos/react-client/echo';\nimport { type KanbanType, useKanbanModel, Kanban } from '@dxos/react-ui-kanban';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nexport const KanbanContainer = ({ kanban }: { kanban: KanbanType; role: string }) => {\n const [cardSchema, setCardSchema] = useState<EchoSchema>();\n const space = getSpace(kanban);\n useEffect(() => {\n if (kanban.cardView && space) {\n setCardSchema(space.db.schemaRegistry.getSchema(kanban.cardView.target!.query.type));\n }\n }, [kanban.cardView, space]);\n\n const objects = useQuery(space, cardSchema ? Filter.schema(cardSchema) : Filter.nothing());\n const filteredObjects = useGlobalFilteredObjects(objects);\n\n const model = useKanbanModel({\n kanban,\n cardSchema,\n items: filteredObjects,\n });\n\n const handleAddColumn = useCallback((columnValue: string) => model?.addEmptyColumn(columnValue), [model]);\n\n const handleAddCard = useCallback(\n (columnValue: string) => {\n if (space && cardSchema) {\n space.db.add(\n create(cardSchema, {\n title: '',\n description: '',\n state: columnValue,\n }),\n );\n }\n },\n [space, cardSchema],\n );\n\n const handleRemoveCard = useCallback(\n (card: { id: string }) => {\n invariant(space);\n space.db.remove(card);\n },\n [space],\n );\n\n const handleRemoveEmptyColumn = useCallback(\n (columnValue: string) => {\n model?.removeColumnFromArrangement(columnValue);\n },\n [model],\n );\n\n return (\n <StackItem.Content toolbar={false}>\n {model ? (\n <Kanban\n model={model}\n onAddCard={handleAddCard}\n onAddColumn={handleAddColumn}\n onRemoveCard={handleRemoveCard}\n onRemoveEmptyColumn={handleRemoveEmptyColumn}\n />\n ) : (\n <span>Loading</span>\n )}\n </StackItem.Content>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\n\nimport { createIntent, useIntentDispatcher } from '@dxos/app-framework';\nimport { Filter, getSpace, useQuery } from '@dxos/react-client/echo';\nimport { ViewEditor, Form } from '@dxos/react-ui-form';\nimport { type KanbanType, KanbanPropsSchema } from '@dxos/react-ui-kanban';\nimport { ViewType } from '@dxos/schema';\n\nimport { KanbanAction } from '../types';\n\ntype KanbanViewEditorProps = { kanban: KanbanType };\n\nexport const KanbanViewEditor = ({ kanban }: KanbanViewEditorProps) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const space = getSpace(kanban);\n\n // TODO(ZaymonFC): The schema registry needs an API where we can query with initial value and\n // endure typename changes. We shouldn't need to manage a subscription at this layer.\n const [schema, setSchema] = useState(\n space && kanban?.cardView?.target?.query?.type\n ? space.db.schemaRegistry.getSchema(kanban.cardView.target.query.type)\n : undefined,\n );\n\n const views = useQuery(space, Filter.schema(ViewType));\n const currentTypename = useMemo(() => kanban?.cardView?.target?.query?.type, [kanban?.cardView?.target?.query?.type]);\n const updateViewTypename = useCallback(\n (newTypename: string) => {\n if (!schema) {\n return;\n }\n const matchingViews = views.filter((view) => view.query.type === currentTypename);\n for (const view of matchingViews) {\n view.query.type = newTypename;\n }\n schema.updateTypename(newTypename);\n },\n [views, schema],\n );\n\n useEffect(() => {\n if (space && kanban?.cardView?.target?.query?.type) {\n const unsubscribe = space.db.schemaRegistry\n .query({ typename: kanban?.cardView?.target?.query?.type })\n .subscribe((query) => {\n const [schema] = query.results;\n if (schema) {\n setSchema(schema);\n }\n });\n\n return unsubscribe;\n }\n }, [space, kanban?.cardView?.target?.query?.type]);\n\n const handleDelete = useCallback(\n (fieldId: string) => dispatch?.(createIntent(KanbanAction.DeleteCardField, { kanban, fieldId })),\n [dispatch, kanban],\n );\n\n if (!space || !schema || !kanban.cardView?.target) {\n return null;\n }\n\n return (\n <>\n <Form\n schema={KanbanPropsSchema}\n values={{ columnField: kanban.columnField }}\n onSave={({ columnField }) => {\n kanban.columnField = columnField;\n kanban.arrangement = undefined;\n }}\n />\n <ViewEditor\n registry={space.db.schemaRegistry}\n schema={schema}\n view={kanban.cardView.target}\n onTypenameChanged={updateViewTypename}\n onDelete={handleDelete}\n />\n </>\n );\n};\n"],
|
|
5
|
+
"mappings": ";;;;;;;AAIA,OAAOA,YAAW;AAElB,SAASC,cAAcC,aAAaC,qBAAqB;;;ACFzD,OAAOC,SAASC,aAAaC,WAAWC,gBAAgB;AAGxD,SAASC,iBAAiB;AAC1B,SAASC,gCAAgC;AACzC,SAASC,QAAQC,UAAUC,UAAUC,cAAc;AACnD,SAA0BC,gBAAgBC,cAAc;AACxD,SAASC,iBAAiB;;AAEnB,IAAMC,kBAAkB,CAAC,EAAEC,OAAM,MAAwC;AAC9E,QAAM,CAACC,YAAYC,aAAAA,IAAiBb,SAAAA;AACpC,QAAMc,QAAQT,SAASM,MAAAA;AACvBZ,YAAU,MAAA;AACR,QAAIY,OAAOI,YAAYD,OAAO;AAC5BD,oBAAcC,MAAME,GAAGC,eAAeC,UAAUP,OAAOI,SAASI,OAAQC,MAAMC,IAAI,CAAA;IACpF;EACF,GAAG;IAACV,OAAOI;IAAUD;GAAM;AAE3B,QAAMQ,UAAUlB,SAASU,OAAOF,aAAaT,OAAOoB,OAAOX,UAAAA,IAAcT,OAAOqB,QAAO,CAAA;AACvF,QAAMC,kBAAkBvB,yBAAyBoB,OAAAA;AAEjD,QAAMI,QAAQnB,eAAe;IAC3BI;IACAC;IACAe,OAAOF;EACT,CAAA;AAEA,QAAMG,kBAAkB9B,YAAY,CAAC+B,gBAAwBH,OAAOI,eAAeD,WAAAA,GAAc;IAACH;GAAM;AAExG,QAAMK,gBAAgBjC,YACpB,CAAC+B,gBAAAA;AACC,QAAIf,SAASF,YAAY;AACvBE,YAAME,GAAGgB,IACP1B,OAAOM,YAAY;QACjBqB,OAAO;QACPC,aAAa;QACbC,OAAON;MACT,CAAA,CAAA;IAEJ;EACF,GACA;IAACf;IAAOF;GAAW;AAGrB,QAAMwB,mBAAmBtC,YACvB,CAACuC,SAAAA;AACCpC,cAAUa,OAAAA,QAAAA;;;;;;;;;AACVA,UAAME,GAAGsB,OAAOD,IAAAA;EAClB,GACA;IAACvB;GAAM;AAGT,QAAMyB,0BAA0BzC,YAC9B,CAAC+B,gBAAAA;AACCH,WAAOc,4BAA4BX,WAAAA;EACrC,GACA;IAACH;GAAM;AAGT,SACE,sBAAA,cAACjB,UAAUgC,SAAO;IAACC,SAAS;KACzBhB,QACC,sBAAA,cAAClB,QAAAA;IACCkB;IACAiB,WAAWZ;IACXa,aAAahB;IACbiB,cAAcT;IACdU,qBAAqBP;OAGvB,sBAAA,cAACQ,QAAAA,MAAK,SAAA,CAAA;AAId;;;AC1EA,OAAOC,UAASC,eAAAA,cAAaC,aAAAA,YAAWC,SAASC,YAAAA,iBAAgB;AAEjE,SAASC,cAAcC,2BAA2B;AAClD,SAASC,UAAAA,SAAQC,YAAAA,WAAUC,YAAAA,iBAAgB;AAC3C,SAASC,YAAYC,YAAY;AACjC,SAA0BC,yBAAyB;AACnD,SAASC,gBAAgB;AAMlB,IAAMC,mBAAmB,CAAC,EAAEC,OAAM,MAAyB;AAChE,QAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AACtC,QAAMC,QAAQC,UAASL,MAAAA;AAIvB,QAAM,CAACM,QAAQC,SAAAA,IAAaC,UAC1BJ,SAASJ,QAAQS,UAAUC,QAAQC,OAAOC,OACtCR,MAAMS,GAAGC,eAAeC,UAAUf,OAAOS,SAASC,OAAOC,MAAMC,IAAI,IACnEI,MAAAA;AAGN,QAAMC,QAAQC,UAASd,OAAOe,QAAOb,OAAOc,QAAAA,CAAAA;AAC5C,QAAMC,kBAAkBC,QAAQ,MAAMtB,QAAQS,UAAUC,QAAQC,OAAOC,MAAM;IAACZ,QAAQS,UAAUC,QAAQC,OAAOC;GAAK;AACpH,QAAMW,qBAAqBC,aACzB,CAACC,gBAAAA;AACC,QAAI,CAACnB,QAAQ;AACX;IACF;AACA,UAAMoB,gBAAgBT,MAAMU,OAAO,CAACC,SAASA,KAAKjB,MAAMC,SAASS,eAAAA;AACjE,eAAWO,QAAQF,eAAe;AAChCE,WAAKjB,MAAMC,OAAOa;IACpB;AACAnB,WAAOuB,eAAeJ,WAAAA;EACxB,GACA;IAACR;IAAOX;GAAO;AAGjBwB,EAAAA,WAAU,MAAA;AACR,QAAI1B,SAASJ,QAAQS,UAAUC,QAAQC,OAAOC,MAAM;AAClD,YAAMmB,cAAc3B,MAAMS,GAAGC,eAC1BH,MAAM;QAAEqB,UAAUhC,QAAQS,UAAUC,QAAQC,OAAOC;MAAK,CAAA,EACxDqB,UAAU,CAACtB,UAAAA;AACV,cAAM,CAACL,OAAAA,IAAUK,MAAMuB;AACvB,YAAI5B,SAAQ;AACVC,oBAAUD,OAAAA;QACZ;MACF,CAAA;AAEF,aAAOyB;IACT;EACF,GAAG;IAAC3B;IAAOJ,QAAQS,UAAUC,QAAQC,OAAOC;GAAK;AAEjD,QAAMuB,eAAeX,aACnB,CAACY,YAAoBlC,WAAWmC,aAAaC,aAAaC,iBAAiB;IAAEvC;IAAQoC;EAAQ,CAAA,CAAA,GAC7F;IAAClC;IAAUF;GAAO;AAGpB,MAAI,CAACI,SAAS,CAACE,UAAU,CAACN,OAAOS,UAAUC,QAAQ;AACjD,WAAO;EACT;AAEA,SACE,gBAAA8B,OAAA,cAAAA,OAAA,UAAA,MACE,gBAAAA,OAAA,cAACC,MAAAA;IACCnC,QAAQoC;IACRC,QAAQ;MAAEC,aAAa5C,OAAO4C;IAAY;IAC1CC,QAAQ,CAAC,EAAED,YAAW,MAAE;AACtB5C,aAAO4C,cAAcA;AACrB5C,aAAO8C,cAAc9B;IACvB;MAEF,gBAAAwB,OAAA,cAACO,YAAAA;IACCC,UAAU5C,MAAMS,GAAGC;IACnBR;IACAsB,MAAM5B,OAAOS,SAASC;IACtBuC,mBAAmB1B;IACnB2B,UAAUf;;AAIlB;;;AF1EA,IAAA,wBAAe,MACbgB,YAAYC,aAAaC,cAAc;EACrCC,cAAc;IACZC,IAAI,GAAGC,aAAAA;IACPC,MAAM;MAAC;MAAW;;IAClBC,QAAQ,CAACC,SAA0CC,SAASD,KAAKE,OAAO;IACxEC,WAAW,CAAC,EAAEH,MAAMF,KAAI,MAAO,gBAAAM,OAAA,cAACC,iBAAAA;MAAgBC,QAAQN,KAAKE;MAASJ;;EACxE,CAAA;EACAH,cAAc;IACZC,IAAI,GAAGC,aAAAA;IACPC,MAAM;IACNC,QAAQ,CAACC,SAA0CC,SAASD,KAAKE,OAAO;IACxEC,WAAW,CAAC,EAAEH,KAAI,MAAO,gBAAAI,OAAA,cAACG,kBAAAA;MAAiBD,QAAQN,KAAKE;;EAC1D,CAAA;CACD;",
|
|
6
|
+
"names": ["React", "Capabilities", "contributes", "createSurface", "React", "useCallback", "useEffect", "useState", "invariant", "useGlobalFilteredObjects", "Filter", "useQuery", "getSpace", "create", "useKanbanModel", "Kanban", "StackItem", "KanbanContainer", "kanban", "cardSchema", "setCardSchema", "space", "cardView", "db", "schemaRegistry", "getSchema", "target", "query", "type", "objects", "schema", "nothing", "filteredObjects", "model", "items", "handleAddColumn", "columnValue", "addEmptyColumn", "handleAddCard", "add", "title", "description", "state", "handleRemoveCard", "card", "remove", "handleRemoveEmptyColumn", "removeColumnFromArrangement", "Content", "toolbar", "onAddCard", "onAddColumn", "onRemoveCard", "onRemoveEmptyColumn", "span", "React", "useCallback", "useEffect", "useMemo", "useState", "createIntent", "useIntentDispatcher", "Filter", "getSpace", "useQuery", "ViewEditor", "Form", "KanbanPropsSchema", "ViewType", "KanbanViewEditor", "kanban", "dispatchPromise", "dispatch", "useIntentDispatcher", "space", "getSpace", "schema", "setSchema", "useState", "cardView", "target", "query", "type", "db", "schemaRegistry", "getSchema", "undefined", "views", "useQuery", "Filter", "ViewType", "currentTypename", "useMemo", "updateViewTypename", "useCallback", "newTypename", "matchingViews", "filter", "view", "updateTypename", "useEffect", "unsubscribe", "typename", "subscribe", "results", "handleDelete", "fieldId", "createIntent", "KanbanAction", "DeleteCardField", "React", "Form", "KanbanPropsSchema", "values", "columnField", "onSave", "arrangement", "ViewEditor", "registry", "onTypenameChanged", "onDelete", "contributes", "Capabilities", "ReactSurface", "createSurface", "id", "KANBAN_PLUGIN", "role", "filter", "data", "isKanban", "subject", "component", "React", "KanbanContainer", "kanban", "KanbanViewEditor"]
|
|
7
|
+
}
|
|
@@ -16,22 +16,34 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
16
16
|
return to;
|
|
17
17
|
};
|
|
18
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var
|
|
20
|
-
__export(
|
|
19
|
+
var chunk_QCB2U2J2_exports = {};
|
|
20
|
+
__export(chunk_QCB2U2J2_exports, {
|
|
21
|
+
KANBAN_PLUGIN: () => KANBAN_PLUGIN,
|
|
21
22
|
KanbanAction: () => KanbanAction,
|
|
22
23
|
createKanban: () => createKanban,
|
|
23
|
-
isKanban: () => isKanban
|
|
24
|
+
isKanban: () => isKanban,
|
|
25
|
+
meta: () => meta
|
|
24
26
|
});
|
|
25
|
-
module.exports = __toCommonJS(
|
|
26
|
-
var import_chunk_MBAGHRFM = require("./chunk-MBAGHRFM.cjs");
|
|
27
|
+
module.exports = __toCommonJS(chunk_QCB2U2J2_exports);
|
|
27
28
|
var import_echo_schema = require("@dxos/echo-schema");
|
|
28
29
|
var import_echo = require("@dxos/react-client/echo");
|
|
29
30
|
var import_react_ui_kanban = require("@dxos/react-ui-kanban");
|
|
30
31
|
var import_testing = require("@dxos/react-ui-kanban/testing");
|
|
31
32
|
var import_schema = require("@dxos/schema");
|
|
33
|
+
var KANBAN_PLUGIN = "dxos.org/plugin/kanban";
|
|
34
|
+
var meta = {
|
|
35
|
+
id: KANBAN_PLUGIN,
|
|
36
|
+
name: "Kanban",
|
|
37
|
+
description: "Kanban board for managing tasks.",
|
|
38
|
+
icon: "ph--kanban--regular",
|
|
39
|
+
source: "https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-kanban",
|
|
40
|
+
tags: [
|
|
41
|
+
"experimental"
|
|
42
|
+
]
|
|
43
|
+
};
|
|
32
44
|
var KanbanAction;
|
|
33
45
|
(function(KanbanAction2) {
|
|
34
|
-
const KANBAN_ACTION = `${
|
|
46
|
+
const KANBAN_ACTION = `${KANBAN_PLUGIN}/action`;
|
|
35
47
|
class Create extends import_echo_schema.S.TaggedClass()(`${KANBAN_ACTION}/create`, {
|
|
36
48
|
input: import_echo_schema.S.Struct({
|
|
37
49
|
name: import_echo_schema.S.optional(import_echo_schema.S.String),
|
|
@@ -70,8 +82,10 @@ var createKanban = async (space) => {
|
|
|
70
82
|
};
|
|
71
83
|
// Annotate the CommonJS export names for ESM import in node:
|
|
72
84
|
0 && (module.exports = {
|
|
85
|
+
KANBAN_PLUGIN,
|
|
73
86
|
KanbanAction,
|
|
74
87
|
createKanban,
|
|
75
|
-
isKanban
|
|
88
|
+
isKanban,
|
|
89
|
+
meta
|
|
76
90
|
});
|
|
77
|
-
//# sourceMappingURL=chunk-
|
|
91
|
+
//# sourceMappingURL=chunk-QCB2U2J2.cjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/types.ts", "../../../src/meta.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\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\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.Struct({\n name: S.optional(S.String),\n space: SpaceSchema,\n }),\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\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 (space: Space) => {\n const { kanban } = await initializeKanban({ space });\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 = {\n id: KANBAN_PLUGIN,\n name: 'Kanban',\n description: 'Kanban board for managing tasks.',\n icon: 'ph--kanban--regular',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-kanban',\n tags: ['experimental'],\n} satisfies PluginMeta;\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,yBAAkB;AAClB,kBAAwC;AACxC,6BAA2B;AAC3B,qBAAiC;AACjC,oBAA4B;ACFrB,IAAMA,gBAAgB;AAEtB,IAAMC,OAAO;EAClBC,IAAIF;EACJG,MAAM;EACNC,aAAa;EACbC,MAAM;EACNC,QAAQ;EACRC,MAAM;IAAC;;AACT;;UDMiBC,eAAAA;AACf,QAAMC,gBAAgB,GAAGT,aAAAA;EAElB,MAAMU,eAAeC,qBAAEC,YAAW,EAAW,GAAGH,aAAAA,WAAwB;IAC7EI,OAAOF,qBAAEG,OAAO;MACdX,MAAMQ,qBAAEI,SAASJ,qBAAEK,MAAM;MACzBC,OAAOC;IACT,CAAA;IACAC,QAAQR,qBAAEG,OAAO;MACfM,QAAQC;IACV,CAAA;EACF,CAAA,EAAA;EAAI;gBARSX,SAAAA;EAUN,MAAMY,wBAAwBX,qBAAEC,YAAW,EAAoB,GAAGH,aAAAA,sBAAmC;IAC1GI,OAAOF,qBAAEG,OAAO;MACdS,QAAQF;MACRG,SAASb,qBAAEK;;MAEXS,cAAcd,qBAAEI,SACdJ,qBAAEG,OAAO;QACPY,OAAOC;;;QAGPC,OAAOjB,qBAAEkB;QACTC,OAAOnB,qBAAEoB;MACX,CAAA,CAAA;IAEJ,CAAA;IACAZ,QAAQR,qBAAEqB;EACZ,CAAA,EAAA;EAAI;gBAhBSV,kBAAAA;AAiBf,GA9BiBd,iBAAAA,eAAAA,CAAAA,EAAAA;AAgDV,IAAMyB,WAAW,CAACb,WAA0CA,UAAU,QAAQA,kBAAkBC;AAEhG,IAAMa,eAAe,OAAOjB,UAAAA;AACjC,QAAM,EAAEM,OAAM,IAAK,UAAMY,iCAAiB;IAAElB;EAAM,CAAA;AAClD,SAAOM;AACT;",
|
|
6
|
+
"names": ["KANBAN_PLUGIN", "meta", "id", "name", "description", "icon", "source", "tags", "KanbanAction", "KANBAN_ACTION", "Create", "S", "TaggedClass", "input", "Struct", "optional", "String", "space", "SpaceSchema", "output", "object", "KanbanType", "DeleteCardField", "kanban", "fieldId", "deletionData", "field", "FieldSchema", "props", "Any", "index", "Number", "Void", "isKanban", "createKanban", "initializeKanban"]
|
|
7
|
+
}
|
package/dist/lib/node/index.cjs
CHANGED
|
@@ -28,147 +28,26 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
28
28
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
29
|
var node_exports = {};
|
|
30
30
|
__export(node_exports, {
|
|
31
|
+
KANBAN_PLUGIN: () => import_chunk_QCB2U2J2.KANBAN_PLUGIN,
|
|
31
32
|
KanbanPlugin: () => KanbanPlugin,
|
|
32
|
-
|
|
33
|
+
meta: () => import_chunk_QCB2U2J2.meta
|
|
33
34
|
});
|
|
34
35
|
module.exports = __toCommonJS(node_exports);
|
|
35
|
-
var
|
|
36
|
-
var import_chunk_MBAGHRFM = require("./chunk-MBAGHRFM.cjs");
|
|
37
|
-
var import_react = __toESM(require("react"));
|
|
36
|
+
var import_chunk_QCB2U2J2 = require("./chunk-QCB2U2J2.cjs");
|
|
38
37
|
var import_app_framework = require("@dxos/app-framework");
|
|
39
|
-
var
|
|
40
|
-
var import_echo = require("@dxos/react-client/echo");
|
|
38
|
+
var import_plugin_client = require("@dxos/plugin-client");
|
|
41
39
|
var import_react_ui_kanban = require("@dxos/react-ui-kanban");
|
|
42
|
-
var import_schema = require("@dxos/schema");
|
|
43
|
-
var import_react2 = __toESM(require("react"));
|
|
44
|
-
var import_invariant2 = require("@dxos/invariant");
|
|
45
|
-
var import_plugin_search = require("@dxos/plugin-search");
|
|
46
|
-
var import_echo2 = require("@dxos/react-client/echo");
|
|
47
|
-
var import_react_ui_kanban2 = require("@dxos/react-ui-kanban");
|
|
48
|
-
var import_react_ui_stack = require("@dxos/react-ui-stack");
|
|
49
|
-
var import_react3 = __toESM(require("react"));
|
|
50
40
|
var import_app_framework2 = require("@dxos/app-framework");
|
|
51
|
-
var
|
|
52
|
-
var
|
|
53
|
-
var
|
|
54
|
-
var import_react_ui_kanban4 = require("@dxos/react-ui-kanban");
|
|
55
|
-
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/experimental/plugin-kanban/src/components/KanbanContainer.tsx";
|
|
56
|
-
var KanbanContainer = ({ kanban }) => {
|
|
57
|
-
const [cardSchema, setCardSchema] = (0, import_react2.useState)();
|
|
58
|
-
const space = (0, import_echo2.getSpace)(kanban);
|
|
59
|
-
(0, import_react2.useEffect)(() => {
|
|
60
|
-
if (kanban.cardView && space) {
|
|
61
|
-
setCardSchema(space.db.schemaRegistry.getSchema(kanban.cardView.target.query.type));
|
|
62
|
-
}
|
|
63
|
-
}, [
|
|
64
|
-
kanban.cardView,
|
|
65
|
-
space
|
|
66
|
-
]);
|
|
67
|
-
const objects = (0, import_echo2.useQuery)(space, cardSchema ? import_echo2.Filter.schema(cardSchema) : import_echo2.Filter.nothing());
|
|
68
|
-
const filteredObjects = (0, import_plugin_search.useGlobalFilteredObjects)(objects);
|
|
69
|
-
const model = (0, import_react_ui_kanban2.useKanbanModel)({
|
|
70
|
-
kanban,
|
|
71
|
-
cardSchema,
|
|
72
|
-
items: filteredObjects
|
|
73
|
-
});
|
|
74
|
-
const handleAddColumn = (0, import_react2.useCallback)((columnValue) => model?.addEmptyColumn(columnValue), [
|
|
75
|
-
model
|
|
76
|
-
]);
|
|
77
|
-
const handleAddCard = (0, import_react2.useCallback)((columnValue) => {
|
|
78
|
-
if (space && cardSchema) {
|
|
79
|
-
space.db.add((0, import_echo2.create)(cardSchema, {
|
|
80
|
-
title: "",
|
|
81
|
-
description: "",
|
|
82
|
-
state: columnValue
|
|
83
|
-
}));
|
|
84
|
-
}
|
|
85
|
-
}, [
|
|
86
|
-
space,
|
|
87
|
-
cardSchema
|
|
88
|
-
]);
|
|
89
|
-
const handleRemoveCard = (0, import_react2.useCallback)((card) => {
|
|
90
|
-
(0, import_invariant2.invariant)(space, void 0, {
|
|
91
|
-
F: __dxlog_file,
|
|
92
|
-
L: 51,
|
|
93
|
-
S: void 0,
|
|
94
|
-
A: [
|
|
95
|
-
"space",
|
|
96
|
-
""
|
|
97
|
-
]
|
|
98
|
-
});
|
|
99
|
-
space.db.remove(card);
|
|
100
|
-
}, [
|
|
101
|
-
space
|
|
102
|
-
]);
|
|
103
|
-
const handleRemoveEmptyColumn = (0, import_react2.useCallback)((columnValue) => {
|
|
104
|
-
model?.removeColumnFromArrangement(columnValue);
|
|
105
|
-
}, [
|
|
106
|
-
model
|
|
107
|
-
]);
|
|
108
|
-
return /* @__PURE__ */ import_react2.default.createElement(import_react_ui_stack.StackItem.Content, {
|
|
109
|
-
toolbar: false
|
|
110
|
-
}, model ? /* @__PURE__ */ import_react2.default.createElement(import_react_ui_kanban2.Kanban, {
|
|
111
|
-
model,
|
|
112
|
-
onAddCard: handleAddCard,
|
|
113
|
-
onAddColumn: handleAddColumn,
|
|
114
|
-
onRemoveCard: handleRemoveCard,
|
|
115
|
-
onRemoveEmptyColumn: handleRemoveEmptyColumn
|
|
116
|
-
}) : /* @__PURE__ */ import_react2.default.createElement("span", null, "Loading"));
|
|
117
|
-
};
|
|
118
|
-
var KanbanViewEditor = ({ kanban }) => {
|
|
119
|
-
const { dispatchPromise: dispatch } = (0, import_app_framework2.useIntentDispatcher)();
|
|
120
|
-
const space = (0, import_echo3.getSpace)(kanban);
|
|
121
|
-
const [schema, setSchema] = (0, import_react3.useState)(space && kanban?.cardView?.target?.query?.type ? space.db.schemaRegistry.getSchema(kanban.cardView.target.query.type) : void 0);
|
|
122
|
-
(0, import_react3.useEffect)(() => {
|
|
123
|
-
if (space && kanban?.cardView?.target?.query?.type) {
|
|
124
|
-
const unsubscribe = space.db.schemaRegistry.query({
|
|
125
|
-
typename: kanban?.cardView?.target?.query?.type
|
|
126
|
-
}).subscribe((query) => {
|
|
127
|
-
const [schema2] = query.results;
|
|
128
|
-
if (schema2) {
|
|
129
|
-
setSchema(schema2);
|
|
130
|
-
}
|
|
131
|
-
});
|
|
132
|
-
return unsubscribe;
|
|
133
|
-
}
|
|
134
|
-
}, [
|
|
135
|
-
space,
|
|
136
|
-
kanban?.cardView?.target?.query?.type
|
|
137
|
-
]);
|
|
138
|
-
const handleDelete = (0, import_react3.useCallback)((fieldId) => dispatch?.((0, import_app_framework2.createIntent)(import_chunk_BE2FRW7E.KanbanAction.DeleteCardField, {
|
|
139
|
-
kanban,
|
|
140
|
-
fieldId
|
|
141
|
-
})), [
|
|
142
|
-
dispatch,
|
|
143
|
-
kanban
|
|
144
|
-
]);
|
|
145
|
-
if (!space || !schema || !kanban.cardView?.target) {
|
|
146
|
-
return null;
|
|
147
|
-
}
|
|
148
|
-
return /* @__PURE__ */ import_react3.default.createElement(import_react3.default.Fragment, null, /* @__PURE__ */ import_react3.default.createElement(import_react_ui_form.Form, {
|
|
149
|
-
schema: import_react_ui_kanban3.KanbanPropsSchema,
|
|
150
|
-
values: {
|
|
151
|
-
columnField: kanban.columnField
|
|
152
|
-
},
|
|
153
|
-
onSave: ({ columnField }) => {
|
|
154
|
-
kanban.columnField = columnField;
|
|
155
|
-
kanban.arrangement = void 0;
|
|
156
|
-
}
|
|
157
|
-
}), /* @__PURE__ */ import_react3.default.createElement(import_react_ui_form.ViewEditor, {
|
|
158
|
-
registry: space.db.schemaRegistry,
|
|
159
|
-
schema,
|
|
160
|
-
view: kanban.cardView.target,
|
|
161
|
-
onDelete: handleDelete
|
|
162
|
-
}));
|
|
163
|
-
};
|
|
164
|
-
var KanbanViewEditor_default = KanbanViewEditor;
|
|
41
|
+
var import_react_ui_kanban2 = require("@dxos/react-ui-kanban");
|
|
42
|
+
var IntentResolver = (0, import_app_framework2.lazy)(() => import("./intent-resolver-6QZ6AMZF.cjs"));
|
|
43
|
+
var ReactSurface = (0, import_app_framework2.lazy)(() => import("./react-surface-MOZ2OTXW.cjs"));
|
|
165
44
|
var translations_default = [
|
|
166
45
|
{
|
|
167
46
|
"en-US": {
|
|
168
|
-
[
|
|
47
|
+
[import_react_ui_kanban2.KanbanType.typename]: {
|
|
169
48
|
"typename label": "Kanban"
|
|
170
49
|
},
|
|
171
|
-
[
|
|
50
|
+
[import_chunk_QCB2U2J2.KANBAN_PLUGIN]: {
|
|
172
51
|
"plugin name": "Kanban",
|
|
173
52
|
"kanban title label": "Title",
|
|
174
53
|
"kanban title placeholder": "New kanban",
|
|
@@ -186,115 +65,57 @@ var translations_default = [
|
|
|
186
65
|
}
|
|
187
66
|
}
|
|
188
67
|
];
|
|
189
|
-
var
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
68
|
+
var KanbanPlugin = () => (0, import_app_framework.definePlugin)(import_chunk_QCB2U2J2.meta, [
|
|
69
|
+
(0, import_app_framework.defineModule)({
|
|
70
|
+
id: `${import_chunk_QCB2U2J2.meta.id}/module/translations`,
|
|
71
|
+
activatesOn: import_app_framework.Events.SetupTranslations,
|
|
72
|
+
activate: () => (0, import_app_framework.contributes)(import_app_framework.Capabilities.Translations, [
|
|
73
|
+
...translations_default,
|
|
74
|
+
...import_react_ui_kanban.translations
|
|
75
|
+
])
|
|
76
|
+
}),
|
|
77
|
+
(0, import_app_framework.defineModule)({
|
|
78
|
+
id: `${import_chunk_QCB2U2J2.meta.id}/module/metadata`,
|
|
79
|
+
activatesOn: (0, import_app_framework.oneOf)(import_app_framework.Events.Startup, import_app_framework.Events.SetupAppGraph),
|
|
80
|
+
activate: () => (0, import_app_framework.contributes)(import_app_framework.Capabilities.Metadata, {
|
|
81
|
+
id: import_react_ui_kanban.KanbanType.typename,
|
|
194
82
|
metadata: {
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
],
|
|
204
|
-
icon: "ph--kanban--regular"
|
|
83
|
+
createObject: (props, options) => (0, import_app_framework.createIntent)(import_chunk_QCB2U2J2.KanbanAction.Create, {
|
|
84
|
+
...props,
|
|
85
|
+
space: options.space
|
|
86
|
+
}),
|
|
87
|
+
placeholder: [
|
|
88
|
+
"kanban title placeholder",
|
|
89
|
+
{
|
|
90
|
+
ns: import_chunk_QCB2U2J2.KANBAN_PLUGIN
|
|
205
91
|
}
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
echo: {
|
|
209
|
-
schema: [
|
|
210
|
-
import_react_ui_kanban.KanbanType
|
|
211
|
-
]
|
|
212
|
-
},
|
|
213
|
-
translations: [
|
|
214
|
-
...translations_default,
|
|
215
|
-
...import_react_ui_kanban.translations
|
|
216
|
-
],
|
|
217
|
-
surface: {
|
|
218
|
-
definitions: () => [
|
|
219
|
-
(0, import_app_framework.createSurface)({
|
|
220
|
-
id: `${import_chunk_MBAGHRFM.KANBAN_PLUGIN}/kanban`,
|
|
221
|
-
role: [
|
|
222
|
-
"article",
|
|
223
|
-
"section"
|
|
224
|
-
],
|
|
225
|
-
filter: (data) => (0, import_chunk_BE2FRW7E.isKanban)(data.subject),
|
|
226
|
-
component: ({ data, role }) => /* @__PURE__ */ import_react.default.createElement(KanbanContainer, {
|
|
227
|
-
kanban: data.subject,
|
|
228
|
-
role
|
|
229
|
-
})
|
|
230
|
-
}),
|
|
231
|
-
(0, import_app_framework.createSurface)({
|
|
232
|
-
id: `${import_chunk_MBAGHRFM.KANBAN_PLUGIN}/settings`,
|
|
233
|
-
role: "complementary--settings",
|
|
234
|
-
filter: (data) => (0, import_chunk_BE2FRW7E.isKanban)(data.subject),
|
|
235
|
-
component: ({ data }) => /* @__PURE__ */ import_react.default.createElement(KanbanViewEditor_default, {
|
|
236
|
-
kanban: data.subject
|
|
237
|
-
})
|
|
238
|
-
})
|
|
239
|
-
]
|
|
240
|
-
},
|
|
241
|
-
intent: {
|
|
242
|
-
resolvers: () => [
|
|
243
|
-
(0, import_app_framework.createResolver)(import_chunk_BE2FRW7E.KanbanAction.Create, async ({ space }) => ({
|
|
244
|
-
data: {
|
|
245
|
-
object: await (0, import_chunk_BE2FRW7E.createKanban)(space)
|
|
246
|
-
}
|
|
247
|
-
})),
|
|
248
|
-
(0, import_app_framework.createResolver)(import_chunk_BE2FRW7E.KanbanAction.DeleteCardField, ({ kanban, fieldId, deletionData }, undo) => {
|
|
249
|
-
(0, import_invariant.invariant)(kanban.cardView, void 0, {
|
|
250
|
-
F: __dxlog_file2,
|
|
251
|
-
L: 58,
|
|
252
|
-
S: void 0,
|
|
253
|
-
A: [
|
|
254
|
-
"kanban.cardView",
|
|
255
|
-
""
|
|
256
|
-
]
|
|
257
|
-
});
|
|
258
|
-
const schema = kanban.cardView.target && (0, import_echo.getSpace)(kanban)?.db.schemaRegistry.getSchema(kanban.cardView.target.query.type);
|
|
259
|
-
(0, import_invariant.invariant)(schema, void 0, {
|
|
260
|
-
F: __dxlog_file2,
|
|
261
|
-
L: 63,
|
|
262
|
-
S: void 0,
|
|
263
|
-
A: [
|
|
264
|
-
"schema",
|
|
265
|
-
""
|
|
266
|
-
]
|
|
267
|
-
});
|
|
268
|
-
const projection = new import_schema.ViewProjection(schema, kanban.cardView.target);
|
|
269
|
-
if (!undo) {
|
|
270
|
-
const { deleted, index } = projection.deleteFieldProjection(fieldId);
|
|
271
|
-
return {
|
|
272
|
-
undoable: {
|
|
273
|
-
message: translations_default[0]["en-US"][import_chunk_MBAGHRFM.KANBAN_PLUGIN]["card field deleted label"],
|
|
274
|
-
data: {
|
|
275
|
-
deletionData: {
|
|
276
|
-
...deleted,
|
|
277
|
-
index
|
|
278
|
-
}
|
|
279
|
-
}
|
|
280
|
-
}
|
|
281
|
-
};
|
|
282
|
-
} else if (undo && deletionData) {
|
|
283
|
-
const { field, props, index } = deletionData;
|
|
284
|
-
projection.setFieldProjection({
|
|
285
|
-
field,
|
|
286
|
-
props
|
|
287
|
-
}, index);
|
|
288
|
-
}
|
|
289
|
-
})
|
|
290
|
-
]
|
|
92
|
+
],
|
|
93
|
+
icon: "ph--kanban--regular"
|
|
291
94
|
}
|
|
292
|
-
}
|
|
293
|
-
}
|
|
294
|
-
|
|
295
|
-
|
|
95
|
+
})
|
|
96
|
+
}),
|
|
97
|
+
(0, import_app_framework.defineModule)({
|
|
98
|
+
id: `${import_chunk_QCB2U2J2.meta.id}/module/schema`,
|
|
99
|
+
activatesOn: import_plugin_client.ClientEvents.SetupClient,
|
|
100
|
+
activate: () => (0, import_app_framework.contributes)(import_plugin_client.ClientCapabilities.Schema, [
|
|
101
|
+
import_react_ui_kanban.KanbanType
|
|
102
|
+
])
|
|
103
|
+
}),
|
|
104
|
+
(0, import_app_framework.defineModule)({
|
|
105
|
+
id: `${import_chunk_QCB2U2J2.meta.id}/module/react-surface`,
|
|
106
|
+
activatesOn: import_app_framework.Events.Startup,
|
|
107
|
+
activate: ReactSurface
|
|
108
|
+
}),
|
|
109
|
+
(0, import_app_framework.defineModule)({
|
|
110
|
+
id: `${import_chunk_QCB2U2J2.meta.id}/module/intent-resolver`,
|
|
111
|
+
activatesOn: import_app_framework.Events.SetupIntents,
|
|
112
|
+
activate: IntentResolver
|
|
113
|
+
})
|
|
114
|
+
]);
|
|
296
115
|
// Annotate the CommonJS export names for ESM import in node:
|
|
297
116
|
0 && (module.exports = {
|
|
298
|
-
|
|
117
|
+
KANBAN_PLUGIN,
|
|
118
|
+
KanbanPlugin,
|
|
119
|
+
meta
|
|
299
120
|
});
|
|
300
121
|
//# sourceMappingURL=index.cjs.map
|