@dxos/plugin-kanban 0.7.5-main.9d26e3a → 0.7.5-main.b19bfc8
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-RSO5XMKU.mjs +173 -0
- package/dist/lib/browser/artifact-definition-RSO5XMKU.mjs.map +7 -0
- package/dist/lib/browser/chunk-ILL6UKZE.mjs +94 -0
- package/dist/lib/browser/chunk-ILL6UKZE.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +70 -247
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/intent-resolver-6BD4KUAU.mjs +122 -0
- package/dist/lib/browser/intent-resolver-6BD4KUAU.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-surface-6NYIVXVG.mjs +285 -0
- package/dist/lib/browser/react-surface-6NYIVXVG.mjs.map +7 -0
- package/dist/lib/browser/types.mjs +7 -2
- package/dist/lib/node/artifact-definition-UTF2PHQN.cjs +189 -0
- package/dist/lib/node/artifact-definition-UTF2PHQN.cjs.map +7 -0
- package/dist/lib/node/{chunk-BE2FRW7E.cjs → chunk-63KJGDFJ.cjs} +57 -15
- package/dist/lib/node/chunk-63KJGDFJ.cjs.map +7 -0
- package/dist/lib/node/index.cjs +67 -236
- package/dist/lib/node/index.cjs.map +4 -4
- package/dist/lib/node/intent-resolver-DHL5HBJM.cjs +136 -0
- package/dist/lib/node/intent-resolver-DHL5HBJM.cjs.map +7 -0
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/react-surface-65D6R6Z7.cjs +301 -0
- package/dist/lib/node/react-surface-65D6R6Z7.cjs.map +7 -0
- package/dist/lib/node/types.cjs +10 -5
- package/dist/lib/node/types.cjs.map +2 -2
- package/dist/lib/node-esm/artifact-definition-MVIL3EEK.mjs +174 -0
- package/dist/lib/node-esm/artifact-definition-MVIL3EEK.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-TZ3QKBLD.mjs +96 -0
- package/dist/lib/node-esm/chunk-TZ3QKBLD.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +70 -247
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/intent-resolver-QQWZXC5O.mjs +123 -0
- package/dist/lib/node-esm/intent-resolver-QQWZXC5O.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/react-surface-4JPB2SZX.mjs +286 -0
- package/dist/lib/node-esm/react-surface-4JPB2SZX.mjs.map +7 -0
- package/dist/lib/node-esm/types.mjs +7 -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/artifact-definition.d.ts +11 -0
- package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +4 -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/KanbanContainer.d.ts +1 -2
- package/dist/types/src/components/KanbanContainer.d.ts.map +1 -1
- package/dist/types/src/components/KanbanViewEditor.d.ts +2 -3
- 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 +2 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +3 -0
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types.d.ts +31 -9
- package/dist/types/src/types.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +26 -29
- package/src/KanbanPlugin.tsx +51 -71
- package/src/capabilities/artifact-definition.ts +131 -0
- package/src/capabilities/index.ts +9 -0
- package/src/capabilities/intent-resolver.ts +65 -0
- package/src/capabilities/react-surface.tsx +89 -0
- package/src/components/KanbanContainer.tsx +38 -37
- package/src/components/KanbanViewEditor.tsx +54 -37
- package/src/components/index.ts +1 -0
- package/src/index.ts +1 -4
- package/src/meta.ts +4 -2
- package/src/translations.ts +1 -0
- package/src/types.ts +34 -20
- package/dist/lib/browser/chunk-JZBAL6SW.mjs +0 -56
- 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 +0 -57
- 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,89 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import React, { useMemo } from 'react';
|
|
6
|
+
|
|
7
|
+
import { Capabilities, contributes, createSurface } from '@dxos/app-framework';
|
|
8
|
+
import { type S } from '@dxos/echo-schema';
|
|
9
|
+
import { findAnnotation } from '@dxos/effect';
|
|
10
|
+
import { type CollectionType } from '@dxos/plugin-space/types';
|
|
11
|
+
import { getSpace, isSpace, type Space } from '@dxos/react-client/echo';
|
|
12
|
+
import { type InputProps, SelectInput, useFormValues } from '@dxos/react-ui-form';
|
|
13
|
+
import { type KanbanType } from '@dxos/react-ui-kanban';
|
|
14
|
+
|
|
15
|
+
import { KanbanContainer, KanbanViewEditor } from '../components';
|
|
16
|
+
import { KANBAN_PLUGIN } from '../meta';
|
|
17
|
+
import { isKanban, InitialSchemaAnnotationId, InitialPivotColumnAnnotationId } from '../types';
|
|
18
|
+
|
|
19
|
+
export default () =>
|
|
20
|
+
contributes(Capabilities.ReactSurface, [
|
|
21
|
+
createSurface({
|
|
22
|
+
id: `${KANBAN_PLUGIN}/kanban`,
|
|
23
|
+
role: ['article', 'section'],
|
|
24
|
+
filter: (data): data is { subject: KanbanType } => isKanban(data.subject),
|
|
25
|
+
component: ({ data, role }) => <KanbanContainer kanban={data.subject} role={role} />,
|
|
26
|
+
}),
|
|
27
|
+
createSurface({
|
|
28
|
+
id: `${KANBAN_PLUGIN}/settings`,
|
|
29
|
+
role: 'complementary--settings',
|
|
30
|
+
filter: (data): data is { subject: KanbanType } => isKanban(data.subject),
|
|
31
|
+
component: ({ data }) => <KanbanViewEditor kanban={data.subject} />,
|
|
32
|
+
}),
|
|
33
|
+
createSurface({
|
|
34
|
+
id: `${KANBAN_PLUGIN}/create-initial-schema-form-[schema]`,
|
|
35
|
+
role: 'form-input',
|
|
36
|
+
filter: (data): data is { prop: string; schema: S.Schema<any>; target: Space | CollectionType | undefined } => {
|
|
37
|
+
const annotation = findAnnotation<boolean>((data.schema as S.Schema.All).ast, InitialSchemaAnnotationId);
|
|
38
|
+
return !!annotation;
|
|
39
|
+
},
|
|
40
|
+
component: ({ data: { target }, ...inputProps }) => {
|
|
41
|
+
const props = inputProps as any as InputProps;
|
|
42
|
+
const space = isSpace(target) ? target : getSpace(target);
|
|
43
|
+
if (!space) {
|
|
44
|
+
return null;
|
|
45
|
+
}
|
|
46
|
+
const schemata = space?.db.schemaRegistry.query().runSync();
|
|
47
|
+
|
|
48
|
+
return <SelectInput {...props} options={schemata.map((schema) => ({ value: schema.typename }))} />;
|
|
49
|
+
},
|
|
50
|
+
}),
|
|
51
|
+
createSurface({
|
|
52
|
+
id: `${KANBAN_PLUGIN}/create-initial-schema-form-[pivot-column]`,
|
|
53
|
+
role: 'form-input',
|
|
54
|
+
filter: (data): data is { prop: string; schema: S.Schema<any>; target: Space | CollectionType | undefined } => {
|
|
55
|
+
const annotation = findAnnotation<boolean>((data.schema as S.Schema.All).ast, InitialPivotColumnAnnotationId);
|
|
56
|
+
return !!annotation;
|
|
57
|
+
},
|
|
58
|
+
component: ({ data: { target }, ...inputProps }) => {
|
|
59
|
+
const props = inputProps as any as InputProps;
|
|
60
|
+
const space = isSpace(target) ? target : getSpace(target);
|
|
61
|
+
if (!space) {
|
|
62
|
+
return null;
|
|
63
|
+
}
|
|
64
|
+
const { initialSchema } = useFormValues();
|
|
65
|
+
const [selectedSchema] = space?.db.schemaRegistry.query({ typename: initialSchema }).runSync();
|
|
66
|
+
|
|
67
|
+
const singleSelectColumns = useMemo(() => {
|
|
68
|
+
if (!selectedSchema?.jsonSchema?.properties) {
|
|
69
|
+
return [];
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
const columns = Object.entries(selectedSchema.jsonSchema.properties).reduce<string[]>((acc, [key, value]) => {
|
|
73
|
+
if (typeof value === 'object' && value?.format === 'single-select') {
|
|
74
|
+
acc.push(key);
|
|
75
|
+
}
|
|
76
|
+
return acc;
|
|
77
|
+
}, []);
|
|
78
|
+
|
|
79
|
+
return columns;
|
|
80
|
+
}, [selectedSchema?.jsonSchema]);
|
|
81
|
+
|
|
82
|
+
if (!initialSchema) {
|
|
83
|
+
return null;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
return <SelectInput {...props} options={singleSelectColumns.map((column) => ({ value: column }))} />;
|
|
87
|
+
},
|
|
88
|
+
}),
|
|
89
|
+
]);
|
|
@@ -4,21 +4,44 @@
|
|
|
4
4
|
|
|
5
5
|
import React, { useCallback, useEffect, useState } from 'react';
|
|
6
6
|
|
|
7
|
+
import { createIntent, useIntentDispatcher } from '@dxos/app-framework';
|
|
7
8
|
import { type EchoSchema } from '@dxos/echo-schema';
|
|
8
|
-
import { invariant } from '@dxos/invariant';
|
|
9
9
|
import { useGlobalFilteredObjects } from '@dxos/plugin-search';
|
|
10
10
|
import { Filter, useQuery, getSpace, create } from '@dxos/react-client/echo';
|
|
11
11
|
import { type KanbanType, useKanbanModel, Kanban } from '@dxos/react-ui-kanban';
|
|
12
12
|
import { StackItem } from '@dxos/react-ui-stack';
|
|
13
|
+
import { ViewProjection } from '@dxos/schema';
|
|
14
|
+
|
|
15
|
+
import { KanbanAction } from '../types';
|
|
13
16
|
|
|
14
17
|
export const KanbanContainer = ({ kanban }: { kanban: KanbanType; role: string }) => {
|
|
15
18
|
const [cardSchema, setCardSchema] = useState<EchoSchema>();
|
|
19
|
+
const [projection, setProjection] = useState<ViewProjection>();
|
|
16
20
|
const space = getSpace(kanban);
|
|
21
|
+
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
22
|
+
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
if (kanban.cardView?.target?.query?.type && space) {
|
|
25
|
+
const query = space.db.schemaRegistry.query({ typename: kanban.cardView.target.query.type });
|
|
26
|
+
const unsubscribe = query.subscribe(
|
|
27
|
+
() => {
|
|
28
|
+
const [schema] = query.results;
|
|
29
|
+
if (schema) {
|
|
30
|
+
setCardSchema(schema);
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
{ fire: true },
|
|
34
|
+
);
|
|
35
|
+
return unsubscribe;
|
|
36
|
+
}
|
|
37
|
+
}, [kanban.cardView?.target?.query, space]);
|
|
38
|
+
|
|
17
39
|
useEffect(() => {
|
|
18
|
-
if (kanban.cardView &&
|
|
19
|
-
|
|
40
|
+
if (kanban.cardView?.target && cardSchema) {
|
|
41
|
+
setProjection(new ViewProjection(cardSchema, kanban.cardView.target));
|
|
20
42
|
}
|
|
21
|
-
|
|
43
|
+
// TODO(ZaymonFC): Is there a better way to get notified about deep changes in the json schema?
|
|
44
|
+
}, [kanban.cardView?.target, cardSchema, JSON.stringify(cardSchema?.jsonSchema)]);
|
|
22
45
|
|
|
23
46
|
const objects = useQuery(space, cardSchema ? Filter.schema(cardSchema) : Filter.nothing());
|
|
24
47
|
const filteredObjects = useGlobalFilteredObjects(objects);
|
|
@@ -26,54 +49,32 @@ export const KanbanContainer = ({ kanban }: { kanban: KanbanType; role: string }
|
|
|
26
49
|
const model = useKanbanModel({
|
|
27
50
|
kanban,
|
|
28
51
|
cardSchema,
|
|
52
|
+
projection,
|
|
29
53
|
items: filteredObjects,
|
|
30
54
|
});
|
|
31
55
|
|
|
32
|
-
const handleAddColumn = useCallback((columnValue: string) => model?.addEmptyColumn(columnValue), [model]);
|
|
33
|
-
|
|
34
56
|
const handleAddCard = useCallback(
|
|
35
|
-
(columnValue: string) => {
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
state: columnValue,
|
|
42
|
-
}),
|
|
43
|
-
);
|
|
57
|
+
(columnValue: string | undefined) => {
|
|
58
|
+
const path = model?.columnFieldPath;
|
|
59
|
+
if (space && cardSchema && path) {
|
|
60
|
+
const card = create(cardSchema, { [path]: columnValue });
|
|
61
|
+
space.db.add(card);
|
|
62
|
+
return card.id;
|
|
44
63
|
}
|
|
45
64
|
},
|
|
46
|
-
[space, cardSchema],
|
|
65
|
+
[space, cardSchema, model],
|
|
47
66
|
);
|
|
48
67
|
|
|
49
68
|
const handleRemoveCard = useCallback(
|
|
50
69
|
(card: { id: string }) => {
|
|
51
|
-
|
|
52
|
-
space.db.remove(card);
|
|
53
|
-
},
|
|
54
|
-
[space],
|
|
55
|
-
);
|
|
56
|
-
|
|
57
|
-
const handleRemoveEmptyColumn = useCallback(
|
|
58
|
-
(columnValue: string) => {
|
|
59
|
-
model?.removeColumnFromArrangement(columnValue);
|
|
70
|
+
void dispatch(createIntent(KanbanAction.DeleteCard, { card }));
|
|
60
71
|
},
|
|
61
|
-
[
|
|
72
|
+
[dispatch],
|
|
62
73
|
);
|
|
63
74
|
|
|
64
75
|
return (
|
|
65
76
|
<StackItem.Content toolbar={false}>
|
|
66
|
-
{model
|
|
67
|
-
<Kanban
|
|
68
|
-
model={model}
|
|
69
|
-
onAddCard={handleAddCard}
|
|
70
|
-
onAddColumn={handleAddColumn}
|
|
71
|
-
onRemoveCard={handleRemoveCard}
|
|
72
|
-
onRemoveEmptyColumn={handleRemoveEmptyColumn}
|
|
73
|
-
/>
|
|
74
|
-
) : (
|
|
75
|
-
<span>Loading</span>
|
|
76
|
-
)}
|
|
77
|
+
{model && <Kanban model={model} onAddCard={handleAddCard} onRemoveCard={handleRemoveCard} />}
|
|
77
78
|
</StackItem.Content>
|
|
78
79
|
);
|
|
79
80
|
};
|
|
@@ -1,72 +1,89 @@
|
|
|
1
1
|
//
|
|
2
|
-
// Copyright
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import React, { useCallback,
|
|
5
|
+
import React, { useCallback, useMemo } from 'react';
|
|
6
6
|
|
|
7
7
|
import { createIntent, useIntentDispatcher } from '@dxos/app-framework';
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
8
|
+
import { FormatEnum } from '@dxos/echo-schema';
|
|
9
|
+
import { invariant } from '@dxos/invariant';
|
|
10
|
+
import { Filter, getSpace, useQuery, useSchema } from '@dxos/react-client/echo';
|
|
11
|
+
import { ViewEditor, Form, SelectInput, type CustomInputMap } from '@dxos/react-ui-form';
|
|
12
|
+
import { type KanbanType, KanbanSettingsSchema } from '@dxos/react-ui-kanban';
|
|
13
|
+
import { ViewType, ViewProjection } from '@dxos/schema';
|
|
11
14
|
|
|
12
15
|
import { KanbanAction } from '../types';
|
|
13
16
|
|
|
14
17
|
type KanbanViewEditorProps = { kanban: KanbanType };
|
|
15
18
|
|
|
16
|
-
const KanbanViewEditor = ({ kanban }: KanbanViewEditorProps) => {
|
|
19
|
+
export const KanbanViewEditor = ({ kanban }: KanbanViewEditorProps) => {
|
|
17
20
|
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
18
21
|
const space = getSpace(kanban);
|
|
22
|
+
const currentTypename = useMemo(() => kanban?.cardView?.target?.query?.type, [kanban?.cardView?.target?.query?.type]);
|
|
23
|
+
const schema = useSchema(space, currentTypename);
|
|
24
|
+
const views = useQuery(space, Filter.schema(ViewType));
|
|
19
25
|
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
+
const updateViewTypename = useCallback(
|
|
27
|
+
(newTypename: string) => {
|
|
28
|
+
invariant(schema);
|
|
29
|
+
const matchingViews = views.filter((view) => view.query.type === currentTypename);
|
|
30
|
+
for (const view of matchingViews) {
|
|
31
|
+
view.query.type = newTypename;
|
|
32
|
+
}
|
|
33
|
+
schema.updateTypename(newTypename);
|
|
34
|
+
},
|
|
35
|
+
[views, schema],
|
|
26
36
|
);
|
|
27
37
|
|
|
28
|
-
useEffect(() => {
|
|
29
|
-
if (space && kanban?.cardView?.target?.query?.type) {
|
|
30
|
-
const unsubscribe = space.db.schemaRegistry
|
|
31
|
-
.query({ typename: kanban?.cardView?.target?.query?.type })
|
|
32
|
-
.subscribe((query) => {
|
|
33
|
-
const [schema] = query.results;
|
|
34
|
-
if (schema) {
|
|
35
|
-
setSchema(schema);
|
|
36
|
-
}
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
return unsubscribe;
|
|
40
|
-
}
|
|
41
|
-
}, [space, kanban?.cardView?.target?.query?.type]);
|
|
42
|
-
|
|
43
38
|
const handleDelete = useCallback(
|
|
44
39
|
(fieldId: string) => dispatch?.(createIntent(KanbanAction.DeleteCardField, { kanban, fieldId })),
|
|
45
40
|
[dispatch, kanban],
|
|
46
41
|
);
|
|
47
42
|
|
|
43
|
+
const projection = useMemo(() => {
|
|
44
|
+
if (kanban?.cardView?.target && schema) {
|
|
45
|
+
return new ViewProjection(schema, kanban.cardView.target);
|
|
46
|
+
}
|
|
47
|
+
}, [kanban?.cardView?.target, schema, JSON.stringify(schema)]);
|
|
48
|
+
|
|
49
|
+
const selectFields = useMemo(() => {
|
|
50
|
+
if (!projection) {
|
|
51
|
+
return [];
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
return projection
|
|
55
|
+
.getFieldProjections()
|
|
56
|
+
.filter((field) => field.props.format === FormatEnum.SingleSelect)
|
|
57
|
+
.map(({ field }) => ({ value: field.id, label: field.path }));
|
|
58
|
+
}, [projection]);
|
|
59
|
+
|
|
60
|
+
const onSave = useCallback(
|
|
61
|
+
(values: Partial<{ columnFieldId: string }>) => {
|
|
62
|
+
kanban.columnFieldId = values.columnFieldId;
|
|
63
|
+
},
|
|
64
|
+
[kanban],
|
|
65
|
+
);
|
|
66
|
+
|
|
67
|
+
const initialValues = useMemo(() => ({ columnFieldId: kanban.columnFieldId }), [kanban]);
|
|
68
|
+
const custom: CustomInputMap = useMemo(
|
|
69
|
+
() => ({ columnFieldId: (props) => <SelectInput {...props} options={selectFields} /> }),
|
|
70
|
+
[selectFields],
|
|
71
|
+
);
|
|
72
|
+
|
|
48
73
|
if (!space || !schema || !kanban.cardView?.target) {
|
|
49
74
|
return null;
|
|
50
75
|
}
|
|
51
76
|
|
|
52
77
|
return (
|
|
53
78
|
<>
|
|
54
|
-
<Form
|
|
55
|
-
schema={KanbanPropsSchema}
|
|
56
|
-
values={{ columnField: kanban.columnField }}
|
|
57
|
-
onSave={({ columnField }) => {
|
|
58
|
-
kanban.columnField = columnField;
|
|
59
|
-
kanban.arrangement = undefined;
|
|
60
|
-
}}
|
|
61
|
-
/>
|
|
79
|
+
<Form schema={KanbanSettingsSchema} values={initialValues} onSave={onSave} autoSave Custom={custom} />
|
|
62
80
|
<ViewEditor
|
|
63
81
|
registry={space.db.schemaRegistry}
|
|
64
82
|
schema={schema}
|
|
65
83
|
view={kanban.cardView.target}
|
|
84
|
+
onTypenameChanged={updateViewTypename}
|
|
66
85
|
onDelete={handleDelete}
|
|
67
86
|
/>
|
|
68
87
|
</>
|
|
69
88
|
);
|
|
70
89
|
};
|
|
71
|
-
|
|
72
|
-
export default KanbanViewEditor;
|
package/src/components/index.ts
CHANGED
package/src/index.ts
CHANGED
package/src/meta.ts
CHANGED
|
@@ -6,11 +6,13 @@ import { type PluginMeta } from '@dxos/app-framework';
|
|
|
6
6
|
|
|
7
7
|
export const KANBAN_PLUGIN = 'dxos.org/plugin/kanban';
|
|
8
8
|
|
|
9
|
-
export
|
|
9
|
+
export const meta = {
|
|
10
10
|
id: KANBAN_PLUGIN,
|
|
11
11
|
name: 'Kanban',
|
|
12
|
-
description:
|
|
12
|
+
description:
|
|
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.',
|
|
13
14
|
icon: 'ph--kanban--regular',
|
|
14
15
|
source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-kanban',
|
|
15
16
|
tags: ['experimental'],
|
|
17
|
+
screenshots: ['https://dxos.network/plugin-details-kanban-dark.png'],
|
|
16
18
|
} satisfies PluginMeta;
|
package/src/translations.ts
CHANGED
package/src/types.ts
CHANGED
|
@@ -1,15 +1,10 @@
|
|
|
1
1
|
//
|
|
2
|
-
// Copyright
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import
|
|
6
|
-
|
|
7
|
-
MetadataRecordsProvides,
|
|
8
|
-
SurfaceProvides,
|
|
9
|
-
TranslationsProvides,
|
|
10
|
-
} from '@dxos/app-framework';
|
|
5
|
+
import { TitleAnnotationId } from '@effect/schema/AST';
|
|
6
|
+
|
|
11
7
|
import { S } from '@dxos/echo-schema';
|
|
12
|
-
import { type SchemaProvides } from '@dxos/plugin-space';
|
|
13
8
|
import { type Space, SpaceSchema } from '@dxos/react-client/echo';
|
|
14
9
|
import { KanbanType } from '@dxos/react-ui-kanban';
|
|
15
10
|
import { initializeKanban } from '@dxos/react-ui-kanban/testing';
|
|
@@ -26,14 +21,32 @@ import { KANBAN_PLUGIN } from './meta';
|
|
|
26
21
|
* by the model (e.g., a query of items based on metadata within a column object).
|
|
27
22
|
*/
|
|
28
23
|
|
|
24
|
+
export const InitialSchemaAnnotationId = Symbol.for('@dxos/plugin-kanban/annotation/InitialSchema');
|
|
25
|
+
export const InitialPivotColumnAnnotationId = Symbol.for('@dxos/plugin-kanban/annotation/InitialPivotColumn');
|
|
26
|
+
|
|
27
|
+
export const CreateKanbanSchema = S.Struct({
|
|
28
|
+
name: S.optional(S.String),
|
|
29
|
+
initialSchema: S.optional(
|
|
30
|
+
S.String.annotations({
|
|
31
|
+
[InitialSchemaAnnotationId]: true,
|
|
32
|
+
[TitleAnnotationId]: 'Select card schema (leave empty to start fresh)',
|
|
33
|
+
}),
|
|
34
|
+
),
|
|
35
|
+
initialPivotColumn: S.optional(
|
|
36
|
+
S.String.annotations({
|
|
37
|
+
[InitialPivotColumnAnnotationId]: true,
|
|
38
|
+
[TitleAnnotationId]: 'Pivot column',
|
|
39
|
+
}),
|
|
40
|
+
),
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
export type CreateKanbanType = S.Schema.Type<typeof CreateKanbanSchema>;
|
|
44
|
+
|
|
29
45
|
export namespace KanbanAction {
|
|
30
46
|
const KANBAN_ACTION = `${KANBAN_PLUGIN}/action`;
|
|
31
47
|
|
|
32
48
|
export class Create extends S.TaggedClass<Create>()(`${KANBAN_ACTION}/create`, {
|
|
33
|
-
input: S.Struct({
|
|
34
|
-
name: S.optional(S.String),
|
|
35
|
-
space: SpaceSchema,
|
|
36
|
-
}),
|
|
49
|
+
input: S.extend(S.Struct({ space: SpaceSchema }), CreateKanbanSchema),
|
|
37
50
|
output: S.Struct({
|
|
38
51
|
object: KanbanType,
|
|
39
52
|
}),
|
|
@@ -56,13 +69,14 @@ export namespace KanbanAction {
|
|
|
56
69
|
}),
|
|
57
70
|
output: S.Void,
|
|
58
71
|
}) {}
|
|
59
|
-
}
|
|
60
72
|
|
|
61
|
-
export
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
73
|
+
export class DeleteCard extends S.TaggedClass<DeleteCard>()(`${KANBAN_ACTION}/delete-card`, {
|
|
74
|
+
input: S.Struct({
|
|
75
|
+
card: S.Any, // The card object to delete
|
|
76
|
+
}),
|
|
77
|
+
output: S.Void,
|
|
78
|
+
}) {}
|
|
79
|
+
}
|
|
66
80
|
|
|
67
81
|
// TODO(burdon): Undo?
|
|
68
82
|
// TODO(burdon): Typescript types (replace proto with annotations?)
|
|
@@ -82,7 +96,7 @@ export type Location = {
|
|
|
82
96
|
|
|
83
97
|
export const isKanban = (object: unknown): object is KanbanType => object != null && object instanceof KanbanType;
|
|
84
98
|
|
|
85
|
-
export const createKanban = async (space: Space) => {
|
|
86
|
-
const { kanban } = await initializeKanban(
|
|
99
|
+
export const createKanban = async (props: { space: Space; initialSchema?: string; initialPivotColumn?: string }) => {
|
|
100
|
+
const { kanban } = await initializeKanban(props);
|
|
87
101
|
return kanban;
|
|
88
102
|
};
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
KANBAN_PLUGIN
|
|
3
|
-
} from "./chunk-LG4OMN5S.mjs";
|
|
4
|
-
|
|
5
|
-
// packages/plugins/experimental/plugin-kanban/src/types.ts
|
|
6
|
-
import { S } from "@dxos/echo-schema";
|
|
7
|
-
import { SpaceSchema } from "@dxos/react-client/echo";
|
|
8
|
-
import { KanbanType } from "@dxos/react-ui-kanban";
|
|
9
|
-
import { initializeKanban } from "@dxos/react-ui-kanban/testing";
|
|
10
|
-
import { FieldSchema } from "@dxos/schema";
|
|
11
|
-
var KanbanAction;
|
|
12
|
-
(function(KanbanAction2) {
|
|
13
|
-
const KANBAN_ACTION = `${KANBAN_PLUGIN}/action`;
|
|
14
|
-
class Create extends S.TaggedClass()(`${KANBAN_ACTION}/create`, {
|
|
15
|
-
input: S.Struct({
|
|
16
|
-
name: S.optional(S.String),
|
|
17
|
-
space: SpaceSchema
|
|
18
|
-
}),
|
|
19
|
-
output: S.Struct({
|
|
20
|
-
object: KanbanType
|
|
21
|
-
})
|
|
22
|
-
}) {
|
|
23
|
-
}
|
|
24
|
-
KanbanAction2.Create = Create;
|
|
25
|
-
class DeleteCardField extends S.TaggedClass()(`${KANBAN_ACTION}/delete-card-field`, {
|
|
26
|
-
input: S.Struct({
|
|
27
|
-
kanban: KanbanType,
|
|
28
|
-
fieldId: S.String,
|
|
29
|
-
// TODO(wittjosiah): Separate fields for undo data?
|
|
30
|
-
deletionData: S.optional(S.Struct({
|
|
31
|
-
field: FieldSchema,
|
|
32
|
-
// TODO(wittjosiah): This creates a type error.
|
|
33
|
-
// props: PropertySchema,
|
|
34
|
-
props: S.Any,
|
|
35
|
-
index: S.Number
|
|
36
|
-
}))
|
|
37
|
-
}),
|
|
38
|
-
output: S.Void
|
|
39
|
-
}) {
|
|
40
|
-
}
|
|
41
|
-
KanbanAction2.DeleteCardField = DeleteCardField;
|
|
42
|
-
})(KanbanAction || (KanbanAction = {}));
|
|
43
|
-
var isKanban = (object) => object != null && object instanceof KanbanType;
|
|
44
|
-
var createKanban = async (space) => {
|
|
45
|
-
const { kanban } = await initializeKanban({
|
|
46
|
-
space
|
|
47
|
-
});
|
|
48
|
-
return kanban;
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
export {
|
|
52
|
-
KanbanAction,
|
|
53
|
-
isKanban,
|
|
54
|
-
createKanban
|
|
55
|
-
};
|
|
56
|
-
//# sourceMappingURL=chunk-JZBAL6SW.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/types.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport type {\n IntentResolverProvides,\n MetadataRecordsProvides,\n SurfaceProvides,\n TranslationsProvides,\n} from '@dxos/app-framework';\nimport { S } from '@dxos/echo-schema';\nimport { type SchemaProvides } from '@dxos/plugin-space';\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\nexport type KanbanPluginProvides = SurfaceProvides &\n IntentResolverProvides &\n MetadataRecordsProvides &\n TranslationsProvides &\n SchemaProvides;\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"],
|
|
5
|
-
"mappings": ";;;;;AAUA,SAASA,SAAS;AAElB,SAAqBC,mBAAmB;AACxC,SAASC,kBAAkB;AAC3B,SAASC,wBAAwB;AACjC,SAASC,mBAAmB;;UAaXC,eAAAA;AACf,QAAMC,gBAAgB,GAAGC,aAAAA;EAElB,MAAMC,eAAeC,EAAEC,YAAW,EAAW,GAAGJ,aAAAA,WAAwB;IAC7EK,OAAOF,EAAEG,OAAO;MACdC,MAAMJ,EAAEK,SAASL,EAAEM,MAAM;MACzBC,OAAOC;IACT,CAAA;IACAC,QAAQT,EAAEG,OAAO;MACfO,QAAQC;IACV,CAAA;EACF,CAAA,EAAA;EAAI;gBARSZ,SAAAA;EAUN,MAAMa,wBAAwBZ,EAAEC,YAAW,EAAoB,GAAGJ,aAAAA,sBAAmC;IAC1GK,OAAOF,EAAEG,OAAO;MACdU,QAAQF;MACRG,SAASd,EAAEM;;MAEXS,cAAcf,EAAEK,SACdL,EAAEG,OAAO;QACPa,OAAOC;;;QAGPC,OAAOlB,EAAEmB;QACTC,OAAOpB,EAAEqB;MACX,CAAA,CAAA;IAEJ,CAAA;IACAZ,QAAQT,EAAEsB;EACZ,CAAA,EAAA;EAAI;gBAhBSV,kBAAAA;AAiBf,GA9BiBhB,iBAAAA,eAAAA,CAAAA,EAAAA;AAsDV,IAAM2B,WAAW,CAACb,WAA0CA,UAAU,QAAQA,kBAAkBC;AAEhG,IAAMa,eAAe,OAAOjB,UAAAA;AACjC,QAAM,EAAEM,OAAM,IAAK,MAAMY,iBAAiB;IAAElB;EAAM,CAAA;AAClD,SAAOM;AACT;",
|
|
6
|
-
"names": ["S", "SpaceSchema", "KanbanType", "initializeKanban", "FieldSchema", "KanbanAction", "KANBAN_ACTION", "KANBAN_PLUGIN", "Create", "S", "TaggedClass", "input", "Struct", "name", "optional", "String", "space", "SpaceSchema", "output", "object", "KanbanType", "DeleteCardField", "kanban", "fieldId", "deletionData", "field", "FieldSchema", "props", "Any", "index", "Number", "Void", "isKanban", "createKanban", "initializeKanban"]
|
|
7
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
// packages/plugins/experimental/plugin-kanban/src/meta.ts
|
|
2
|
-
var KANBAN_PLUGIN = "dxos.org/plugin/kanban";
|
|
3
|
-
var meta_default = {
|
|
4
|
-
id: KANBAN_PLUGIN,
|
|
5
|
-
name: "Kanban",
|
|
6
|
-
description: "Kanban board for managing tasks.",
|
|
7
|
-
icon: "ph--kanban--regular",
|
|
8
|
-
source: "https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-kanban",
|
|
9
|
-
tags: [
|
|
10
|
-
"experimental"
|
|
11
|
-
]
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
export {
|
|
15
|
-
KANBAN_PLUGIN,
|
|
16
|
-
meta_default
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=chunk-LG4OMN5S.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/meta.ts"],
|
|
4
|
-
"sourcesContent": ["//\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 default {\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": ";AAMO,IAAMA,gBAAgB;AAE7B,IAAA,eAAe;EACbC,IAAID;EACJE,MAAM;EACNC,aAAa;EACbC,MAAM;EACNC,QAAQ;EACRC,MAAM;IAAC;;AACT;",
|
|
6
|
-
"names": ["KANBAN_PLUGIN", "id", "name", "description", "icon", "source", "tags"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/types.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport type {\n IntentResolverProvides,\n MetadataRecordsProvides,\n SurfaceProvides,\n TranslationsProvides,\n} from '@dxos/app-framework';\nimport { S } from '@dxos/echo-schema';\nimport { type SchemaProvides } from '@dxos/plugin-space';\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\nexport type KanbanPluginProvides = SurfaceProvides &\n IntentResolverProvides &\n MetadataRecordsProvides &\n TranslationsProvides &\n SchemaProvides;\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"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,yBAAkB;AAElB,kBAAwC;AACxC,6BAA2B;AAC3B,qBAAiC;AACjC,oBAA4B;;UAaXA,eAAAA;AACf,QAAMC,gBAAgB,GAAGC,mCAAAA;EAElB,MAAMC,eAAeC,qBAAEC,YAAW,EAAW,GAAGJ,aAAAA,WAAwB;IAC7EK,OAAOF,qBAAEG,OAAO;MACdC,MAAMJ,qBAAEK,SAASL,qBAAEM,MAAM;MACzBC,OAAOC;IACT,CAAA;IACAC,QAAQT,qBAAEG,OAAO;MACfO,QAAQC;IACV,CAAA;EACF,CAAA,EAAA;EAAI;gBARSZ,SAAAA;EAUN,MAAMa,wBAAwBZ,qBAAEC,YAAW,EAAoB,GAAGJ,aAAAA,sBAAmC;IAC1GK,OAAOF,qBAAEG,OAAO;MACdU,QAAQF;MACRG,SAASd,qBAAEM;;MAEXS,cAAcf,qBAAEK,SACdL,qBAAEG,OAAO;QACPa,OAAOC;;;QAGPC,OAAOlB,qBAAEmB;QACTC,OAAOpB,qBAAEqB;MACX,CAAA,CAAA;IAEJ,CAAA;IACAZ,QAAQT,qBAAEsB;EACZ,CAAA,EAAA;EAAI;gBAhBSV,kBAAAA;AAiBf,GA9BiBhB,iBAAAA,eAAAA,CAAAA,EAAAA;AAsDV,IAAM2B,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": ["KanbanAction", "KANBAN_ACTION", "KANBAN_PLUGIN", "Create", "S", "TaggedClass", "input", "Struct", "name", "optional", "String", "space", "SpaceSchema", "output", "object", "KanbanType", "DeleteCardField", "kanban", "fieldId", "deletionData", "field", "FieldSchema", "props", "Any", "index", "Number", "Void", "isKanban", "createKanban", "initializeKanban"]
|
|
7
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
var chunk_MBAGHRFM_exports = {};
|
|
20
|
-
__export(chunk_MBAGHRFM_exports, {
|
|
21
|
-
KANBAN_PLUGIN: () => KANBAN_PLUGIN,
|
|
22
|
-
meta_default: () => meta_default
|
|
23
|
-
});
|
|
24
|
-
module.exports = __toCommonJS(chunk_MBAGHRFM_exports);
|
|
25
|
-
var KANBAN_PLUGIN = "dxos.org/plugin/kanban";
|
|
26
|
-
var meta_default = {
|
|
27
|
-
id: KANBAN_PLUGIN,
|
|
28
|
-
name: "Kanban",
|
|
29
|
-
description: "Kanban board for managing tasks.",
|
|
30
|
-
icon: "ph--kanban--regular",
|
|
31
|
-
source: "https://github.com/dxos/dxos/tree/main/packages/plugins/experimental/plugin-kanban",
|
|
32
|
-
tags: [
|
|
33
|
-
"experimental"
|
|
34
|
-
]
|
|
35
|
-
};
|
|
36
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
37
|
-
0 && (module.exports = {
|
|
38
|
-
KANBAN_PLUGIN,
|
|
39
|
-
meta_default
|
|
40
|
-
});
|
|
41
|
-
//# sourceMappingURL=chunk-MBAGHRFM.cjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/meta.ts"],
|
|
4
|
-
"sourcesContent": ["//\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 default {\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": ";;;;;;;;;;;;;;;;;;;;;;;;AAMO,IAAMA,gBAAgB;AAE7B,IAAA,eAAe;EACbC,IAAID;EACJE,MAAM;EACNC,aAAa;EACbC,MAAM;EACNC,QAAQ;EACRC,MAAM;IAAC;;AACT;",
|
|
6
|
-
"names": ["KANBAN_PLUGIN", "id", "name", "description", "icon", "source", "tags"]
|
|
7
|
-
}
|