@dxos/plugin-board 0.8.4-main.1da679c

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (66) hide show
  1. package/LICENSE +8 -0
  2. package/README.md +15 -0
  3. package/dist/lib/browser/chunk-V67SBM4U.mjs +59 -0
  4. package/dist/lib/browser/chunk-V67SBM4U.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-YYCPOFRP.mjs +106 -0
  6. package/dist/lib/browser/chunk-YYCPOFRP.mjs.map +7 -0
  7. package/dist/lib/browser/index.mjs +91 -0
  8. package/dist/lib/browser/index.mjs.map +7 -0
  9. package/dist/lib/browser/intent-resolver-AHP36LHF.mjs +33 -0
  10. package/dist/lib/browser/intent-resolver-AHP36LHF.mjs.map +7 -0
  11. package/dist/lib/browser/meta.json +1 -0
  12. package/dist/lib/browser/react-surface-NRTYEQIC.mjs +30 -0
  13. package/dist/lib/browser/react-surface-NRTYEQIC.mjs.map +7 -0
  14. package/dist/lib/browser/types/index.mjs +7 -0
  15. package/dist/lib/browser/types/index.mjs.map +7 -0
  16. package/dist/lib/node-esm/chunk-RNEIWFZQ.mjs +108 -0
  17. package/dist/lib/node-esm/chunk-RNEIWFZQ.mjs.map +7 -0
  18. package/dist/lib/node-esm/chunk-XCGDC6OV.mjs +60 -0
  19. package/dist/lib/node-esm/chunk-XCGDC6OV.mjs.map +7 -0
  20. package/dist/lib/node-esm/index.mjs +92 -0
  21. package/dist/lib/node-esm/index.mjs.map +7 -0
  22. package/dist/lib/node-esm/intent-resolver-HORX66Z6.mjs +34 -0
  23. package/dist/lib/node-esm/intent-resolver-HORX66Z6.mjs.map +7 -0
  24. package/dist/lib/node-esm/meta.json +1 -0
  25. package/dist/lib/node-esm/react-surface-FUC4ZBPA.mjs +31 -0
  26. package/dist/lib/node-esm/react-surface-FUC4ZBPA.mjs.map +7 -0
  27. package/dist/lib/node-esm/types/index.mjs +8 -0
  28. package/dist/lib/node-esm/types/index.mjs.map +7 -0
  29. package/dist/types/src/BoardPlugin.d.ts +2 -0
  30. package/dist/types/src/BoardPlugin.d.ts.map +1 -0
  31. package/dist/types/src/capabilities/index.d.ts +3 -0
  32. package/dist/types/src/capabilities/index.d.ts.map +1 -0
  33. package/dist/types/src/capabilities/intent-resolver.d.ts +4 -0
  34. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -0
  35. package/dist/types/src/capabilities/react-surface.d.ts +4 -0
  36. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  37. package/dist/types/src/components/BoardContainer.d.ts +8 -0
  38. package/dist/types/src/components/BoardContainer.d.ts.map +1 -0
  39. package/dist/types/src/components/BoardContainer.stories.d.ts +44 -0
  40. package/dist/types/src/components/BoardContainer.stories.d.ts.map +1 -0
  41. package/dist/types/src/components/index.d.ts +2 -0
  42. package/dist/types/src/components/index.d.ts.map +1 -0
  43. package/dist/types/src/index.d.ts +5 -0
  44. package/dist/types/src/index.d.ts.map +1 -0
  45. package/dist/types/src/meta.d.ts +3 -0
  46. package/dist/types/src/meta.d.ts.map +1 -0
  47. package/dist/types/src/translations.d.ts +19 -0
  48. package/dist/types/src/translations.d.ts.map +1 -0
  49. package/dist/types/src/types/Board.d.ts +88 -0
  50. package/dist/types/src/types/Board.d.ts.map +1 -0
  51. package/dist/types/src/types/index.d.ts +2 -0
  52. package/dist/types/src/types/index.d.ts.map +1 -0
  53. package/dist/types/tsconfig.tsbuildinfo +1 -0
  54. package/package.json +89 -0
  55. package/src/BoardPlugin.tsx +58 -0
  56. package/src/capabilities/index.ts +8 -0
  57. package/src/capabilities/intent-resolver.ts +34 -0
  58. package/src/capabilities/react-surface.tsx +22 -0
  59. package/src/components/BoardContainer.stories.tsx +122 -0
  60. package/src/components/BoardContainer.tsx +89 -0
  61. package/src/components/index.ts +5 -0
  62. package/src/index.ts +9 -0
  63. package/src/meta.ts +15 -0
  64. package/src/translations.ts +27 -0
  65. package/src/types/Board.ts +47 -0
  66. package/src/types/index.ts +5 -0
package/LICENSE ADDED
@@ -0,0 +1,8 @@
1
+ MIT License
2
+ Copyright (c) 2022 DXOS
3
+
4
+ Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
5
+
6
+ The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
7
+
8
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,15 @@
1
+ # @dxos/plugin-board
2
+
3
+ Surface plugin for card baords.
4
+
5
+ ## DXOS Resources
6
+
7
+ - [Website](https://dxos.org)
8
+ - [Developer Documentation](https://docs.dxos.org)
9
+ - Talk to us on [Discord](https://dxos.org/discord)
10
+
11
+ ## Contributions
12
+
13
+ Your ideas, issues, and code are most welcome. Please take a look at our [community code of conduct](https://github.com/dxos/dxos/blob/main/CODE_OF_CONDUCT.md), the [issue guide](https://github.com/dxos/dxos/blob/main/CONTRIBUTING.md#submitting-issues), and the [PR contribution guide](https://github.com/dxos/dxos/blob/main/CONTRIBUTING.md#submitting-prs).
14
+
15
+ License: [MIT](./LICENSE) Copyright 2023 © DXOS
@@ -0,0 +1,59 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __export = (target, all) => {
3
+ for (var name in all)
4
+ __defProp(target, name, { get: all[name], enumerable: true });
5
+ };
6
+
7
+ // src/types/Board.ts
8
+ var Board_exports = {};
9
+ __export(Board_exports, {
10
+ Board: () => Board,
11
+ Create: () => Create,
12
+ makeBoard: () => makeBoard
13
+ });
14
+ import { Schema } from "effect";
15
+ import { Obj, Type } from "@dxos/echo";
16
+ import { LabelAnnotation } from "@dxos/echo-schema";
17
+ import { BoardLayout, defaultLayout } from "@dxos/react-ui-board";
18
+
19
+ // src/meta.ts
20
+ var meta = {
21
+ id: "dxos.org/plugin/board",
22
+ name: "Board",
23
+ description: "A spatial, infinite canvas app combining notes, media, and whiteboarding in a tactile, visual interface.",
24
+ icon: "ph--squares-four--regular",
25
+ source: "https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-board",
26
+ screenshots: []
27
+ };
28
+
29
+ // src/types/Board.ts
30
+ var Board = Schema.Struct({
31
+ name: Schema.optional(Schema.String),
32
+ items: Schema.mutable(Schema.Array(Type.Ref(Type.Expando))),
33
+ layout: Schema.mutable(BoardLayout)
34
+ }).pipe(Type.Obj({
35
+ typename: "dxos.org/type/Board",
36
+ version: "0.1.0"
37
+ }), LabelAnnotation.set([
38
+ "name"
39
+ ]));
40
+ var makeBoard = (props = {}) => Obj.make(Board, {
41
+ items: [],
42
+ layout: defaultLayout,
43
+ ...props
44
+ });
45
+ var Create = class extends Schema.TaggedClass()(`${meta.id}/action/create`, {
46
+ input: Schema.Struct({
47
+ name: Schema.optional(Schema.String)
48
+ }),
49
+ output: Schema.Struct({
50
+ object: Board
51
+ })
52
+ }) {
53
+ };
54
+
55
+ export {
56
+ meta,
57
+ Board_exports
58
+ };
59
+ //# sourceMappingURL=chunk-V67SBM4U.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/types/Board.ts", "../../../src/meta.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Schema } from 'effect';\n\nimport { Obj, Type } from '@dxos/echo';\nimport { LabelAnnotation } from '@dxos/echo-schema';\nimport { BoardLayout, defaultLayout } from '@dxos/react-ui-board';\n\nimport { meta } from '../meta';\n\n/**\n * Board and layout.\n */\nexport const Board = Schema.Struct({\n name: Schema.optional(Schema.String),\n items: Schema.mutable(Schema.Array(Type.Ref(Type.Expando))),\n layout: Schema.mutable(BoardLayout),\n}).pipe(\n Type.Obj({\n typename: 'dxos.org/type/Board',\n version: '0.1.0',\n }),\n LabelAnnotation.set(['name']),\n);\n\nexport interface Board extends Schema.Schema.Type<typeof Board> {}\n\nexport const makeBoard = (props: Partial<Obj.MakeProps<typeof Board>> = {}) =>\n Obj.make(Board, {\n items: [],\n layout: defaultLayout,\n ...props,\n });\n\n/**\n * Create board.\n */\nexport class Create extends Schema.TaggedClass<Create>()(`${meta.id}/action/create`, {\n input: Schema.Struct({\n name: Schema.optional(Schema.String),\n }),\n output: Schema.Struct({\n object: Board,\n }),\n}) {}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\n\nexport const meta: PluginMeta = {\n id: 'dxos.org/plugin/board',\n name: 'Board',\n description:\n 'A spatial, infinite canvas app combining notes, media, and whiteboarding in a tactile, visual interface.',\n icon: 'ph--squares-four--regular',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-board',\n screenshots: [],\n};\n"],
5
+ "mappings": ";;;;;;;AAAA;;;;;;AAIA,SAASA,cAAc;AAEvB,SAASC,KAAKC,YAAY;AAC1B,SAASC,uBAAuB;AAChC,SAASC,aAAaC,qBAAqB;;;ACFpC,IAAMC,OAAmB;EAC9BC,IAAI;EACJC,MAAM;EACNC,aACE;EACFC,MAAM;EACNC,QAAQ;EACRC,aAAa,CAAA;AACf;;;ADCO,IAAMC,QAAQC,OAAOC,OAAO;EACjCC,MAAMF,OAAOG,SAASH,OAAOI,MAAM;EACnCC,OAAOL,OAAOM,QAAQN,OAAOO,MAAMC,KAAKC,IAAID,KAAKE,OAAO,CAAA,CAAA;EACxDC,QAAQX,OAAOM,QAAQM,WAAAA;AACzB,CAAA,EAAGC,KACDL,KAAKM,IAAI;EACPC,UAAU;EACVC,SAAS;AACX,CAAA,GACAC,gBAAgBC,IAAI;EAAC;CAAO,CAAA;AAKvB,IAAMC,YAAY,CAACC,QAA8C,CAAC,MACvEN,IAAIO,KAAKtB,OAAO;EACdM,OAAO,CAAA;EACPM,QAAQW;EACR,GAAGF;AACL,CAAA;AAKK,IAAMG,SAAN,cAAqBvB,OAAOwB,YAAW,EAAW,GAAGC,KAAKC,EAAE,kBAAkB;EACnFC,OAAO3B,OAAOC,OAAO;IACnBC,MAAMF,OAAOG,SAASH,OAAOI,MAAM;EACrC,CAAA;EACAwB,QAAQ5B,OAAOC,OAAO;IACpB4B,QAAQ9B;EACV,CAAA;AACF,CAAA,EAAA;AAAI;",
6
+ "names": ["Schema", "Obj", "Type", "LabelAnnotation", "BoardLayout", "defaultLayout", "meta", "id", "name", "description", "icon", "source", "screenshots", "Board", "Schema", "Struct", "name", "optional", "String", "items", "mutable", "Array", "Type", "Ref", "Expando", "layout", "BoardLayout", "pipe", "Obj", "typename", "version", "LabelAnnotation", "set", "makeBoard", "props", "make", "defaultLayout", "Create", "TaggedClass", "meta", "id", "input", "output", "object"]
7
+ }
@@ -0,0 +1,106 @@
1
+ // src/components/BoardContainer.tsx
2
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
3
+ import React, { useCallback, useRef } from "react";
4
+ import { Surface, createIntent, useIntentDispatcher } from "@dxos/app-framework";
5
+ import { getSpace } from "@dxos/client/echo";
6
+ import { Ref } from "@dxos/echo";
7
+ import { invariant } from "@dxos/invariant";
8
+ import { SpaceAction } from "@dxos/plugin-space/types";
9
+ import { useSignalsMemo } from "@dxos/react-ui";
10
+ import { Board } from "@dxos/react-ui-board";
11
+ import { StackItem } from "@dxos/react-ui-stack";
12
+ import { isNonNullable } from "@dxos/util";
13
+ var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-board/src/components/BoardContainer.tsx";
14
+ var BoardContainer = ({ board }) => {
15
+ var _effect = _useSignals();
16
+ try {
17
+ const { dispatchPromise: dispatch } = useIntentDispatcher();
18
+ const controller = useRef(null);
19
+ const items = useSignalsMemo(() => board.items.map((ref) => ref.target).filter(isNonNullable), [
20
+ board
21
+ ]);
22
+ const handleAdd = useCallback(async (position = {
23
+ x: 0,
24
+ y: 0
25
+ }) => {
26
+ const space = getSpace(board);
27
+ invariant(space, void 0, {
28
+ F: __dxlog_file,
29
+ L: 32,
30
+ S: void 0,
31
+ A: [
32
+ "space",
33
+ ""
34
+ ]
35
+ });
36
+ await dispatch(createIntent(SpaceAction.OpenCreateObject, {
37
+ target: space,
38
+ navigable: false,
39
+ onCreateObject: (object) => {
40
+ board.items.push(Ref.make(object));
41
+ console.log(board.items.length);
42
+ board.layout.cells[object.id] = {
43
+ ...position,
44
+ width: 1,
45
+ height: 1
46
+ };
47
+ controller.current?.center(position);
48
+ }
49
+ }));
50
+ }, [
51
+ board,
52
+ controller,
53
+ dispatch
54
+ ]);
55
+ const handleDelete = useCallback((id) => {
56
+ const idx = board.items.findIndex((ref) => ref.dxn.asEchoDXN()?.echoId === id);
57
+ if (idx !== -1) {
58
+ board.items.splice(idx, 1);
59
+ }
60
+ delete board.layout.cells[id];
61
+ }, [
62
+ board
63
+ ]);
64
+ const handleMove = useCallback((id, position) => {
65
+ const layout = board.layout.cells[id];
66
+ board.layout.cells[id] = {
67
+ ...layout,
68
+ ...position
69
+ };
70
+ }, [
71
+ board
72
+ ]);
73
+ return /* @__PURE__ */ React.createElement(Board.Root, {
74
+ ref: controller,
75
+ layout: board.layout,
76
+ onAdd: handleAdd,
77
+ onDelete: handleDelete,
78
+ onMove: handleMove
79
+ }, /* @__PURE__ */ React.createElement(StackItem.Content, {
80
+ toolbar: true,
81
+ classNames: "overflow-hidden"
82
+ }, /* @__PURE__ */ React.createElement(Board.Toolbar, null), /* @__PURE__ */ React.createElement(Board.Container, null, /* @__PURE__ */ React.createElement(Board.Viewport, {
83
+ classNames: "border-none"
84
+ }, /* @__PURE__ */ React.createElement(Board.Backdrop, null), /* @__PURE__ */ React.createElement(Board.Content, null, items?.map((item, index) => /* @__PURE__ */ React.createElement(Board.Cell, {
85
+ item,
86
+ key: index,
87
+ layout: board.layout?.cells[item.id] ?? {
88
+ x: 0,
89
+ y: 0
90
+ }
91
+ }, /* @__PURE__ */ React.createElement(Surface, {
92
+ role: "card--extrinsic",
93
+ data: {
94
+ subject: item
95
+ },
96
+ limit: 1
97
+ }))))))));
98
+ } finally {
99
+ _effect.f();
100
+ }
101
+ };
102
+
103
+ export {
104
+ BoardContainer
105
+ };
106
+ //# sourceMappingURL=chunk-YYCPOFRP.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/BoardContainer.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useRef } from 'react';\n\nimport { Surface, createIntent, useIntentDispatcher } from '@dxos/app-framework';\nimport { getSpace } from '@dxos/client/echo';\nimport { type Obj, Ref } from '@dxos/echo';\nimport { invariant } from '@dxos/invariant';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { useSignalsMemo } from '@dxos/react-ui';\nimport { Board, type BoardController, type BoardRootProps } from '@dxos/react-ui-board';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { isNonNullable } from '@dxos/util';\n\nimport { type Board as BoardType } from '../types';\n\nexport type BoardContainerProps = {\n role?: string;\n board: BoardType.Board;\n};\n\nexport const BoardContainer = ({ board }: BoardContainerProps) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const controller = useRef<BoardController>(null);\n const items = useSignalsMemo(() => board.items.map((ref) => ref.target).filter(isNonNullable), [board]);\n\n const handleAdd = useCallback<NonNullable<BoardRootProps['onAdd']>>(\n async (position = { x: 0, y: 0 }) => {\n const space = getSpace(board);\n invariant(space);\n await dispatch(\n createIntent(SpaceAction.OpenCreateObject, {\n target: space,\n navigable: false,\n onCreateObject: (object: Obj.Any) => {\n board.items.push(Ref.make(object));\n console.log(board.items.length);\n board.layout.cells[object.id] = { ...position, width: 1, height: 1 };\n controller.current?.center(position);\n },\n }),\n );\n },\n [board, controller, dispatch],\n );\n\n // TODO(burdon): Use intents so can be undone.\n const handleDelete = useCallback<NonNullable<BoardRootProps['onDelete']>>(\n (id) => {\n // TODO(burdon): Impl. DXN.equals and pass in DXN from `id`.\n const idx = board.items.findIndex((ref) => ref.dxn.asEchoDXN()?.echoId === id);\n if (idx !== -1) {\n board.items.splice(idx, 1);\n }\n delete board.layout.cells[id];\n },\n [board],\n );\n\n const handleMove = useCallback<NonNullable<BoardRootProps['onMove']>>(\n (id, position) => {\n const layout = board.layout.cells[id];\n board.layout.cells[id] = { ...layout, ...position };\n },\n [board],\n );\n\n return (\n <Board.Root ref={controller} layout={board.layout} onAdd={handleAdd} onDelete={handleDelete} onMove={handleMove}>\n <StackItem.Content toolbar classNames='overflow-hidden'>\n <Board.Toolbar />\n <Board.Container>\n <Board.Viewport classNames='border-none'>\n <Board.Backdrop />\n <Board.Content>\n {items?.map((item, index) => (\n <Board.Cell item={item} key={index} layout={board.layout?.cells[item.id] ?? { x: 0, y: 0 }}>\n <Surface role='card--extrinsic' data={{ subject: item }} limit={1} />\n </Board.Cell>\n ))}\n </Board.Content>\n </Board.Viewport>\n </Board.Container>\n </StackItem.Content>\n </Board.Root>\n );\n};\n"],
5
+ "mappings": ";;AAIA,OAAOA,SAASC,aAAaC,cAAc;AAE3C,SAASC,SAASC,cAAcC,2BAA2B;AAC3D,SAASC,gBAAgB;AACzB,SAAmBC,WAAW;AAC9B,SAASC,iBAAiB;AAC1B,SAASC,mBAAmB;AAC5B,SAASC,sBAAsB;AAC/B,SAASC,aAAwD;AACjE,SAASC,iBAAiB;AAC1B,SAASC,qBAAqB;;AASvB,IAAMC,iBAAiB,CAAC,EAAEC,MAAK,MAAuB;;;AAC3D,UAAM,EAAEC,iBAAiBC,SAAQ,IAAKZ,oBAAAA;AACtC,UAAMa,aAAahB,OAAwB,IAAA;AAC3C,UAAMiB,QAAQT,eAAe,MAAMK,MAAMI,MAAMC,IAAI,CAACC,QAAQA,IAAIC,MAAM,EAAEC,OAAOV,aAAAA,GAAgB;MAACE;KAAM;AAEtG,UAAMS,YAAYvB,YAChB,OAAOwB,WAAW;MAAEC,GAAG;MAAGC,GAAG;IAAE,MAAC;AAC9B,YAAMC,QAAQtB,SAASS,KAAAA;AACvBP,gBAAUoB,OAAAA,QAAAA;;;;;;;;;AACV,YAAMX,SACJb,aAAaK,YAAYoB,kBAAkB;QACzCP,QAAQM;QACRE,WAAW;QACXC,gBAAgB,CAACC,WAAAA;AACfjB,gBAAMI,MAAMc,KAAK1B,IAAI2B,KAAKF,MAAAA,CAAAA;AAC1BG,kBAAQC,IAAIrB,MAAMI,MAAMkB,MAAM;AAC9BtB,gBAAMuB,OAAOC,MAAMP,OAAOQ,EAAE,IAAI;YAAE,GAAGf;YAAUgB,OAAO;YAAGC,QAAQ;UAAE;AACnExB,qBAAWyB,SAASC,OAAOnB,QAAAA;QAC7B;MACF,CAAA,CAAA;IAEJ,GACA;MAACV;MAAOG;MAAYD;KAAS;AAI/B,UAAM4B,eAAe5C,YACnB,CAACuC,OAAAA;AAEC,YAAMM,MAAM/B,MAAMI,MAAM4B,UAAU,CAAC1B,QAAQA,IAAI2B,IAAIC,UAAS,GAAIC,WAAWV,EAAAA;AAC3E,UAAIM,QAAQ,IAAI;AACd/B,cAAMI,MAAMgC,OAAOL,KAAK,CAAA;MAC1B;AACA,aAAO/B,MAAMuB,OAAOC,MAAMC,EAAAA;IAC5B,GACA;MAACzB;KAAM;AAGT,UAAMqC,aAAanD,YACjB,CAACuC,IAAIf,aAAAA;AACH,YAAMa,SAASvB,MAAMuB,OAAOC,MAAMC,EAAAA;AAClCzB,YAAMuB,OAAOC,MAAMC,EAAAA,IAAM;QAAE,GAAGF;QAAQ,GAAGb;MAAS;IACpD,GACA;MAACV;KAAM;AAGT,WACE,sBAAA,cAACJ,MAAM0C,MAAI;MAAChC,KAAKH;MAAYoB,QAAQvB,MAAMuB;MAAQgB,OAAO9B;MAAW+B,UAAUV;MAAcW,QAAQJ;OACnG,sBAAA,cAACxC,UAAU6C,SAAO;MAACC,SAAAA;MAAQC,YAAW;OACpC,sBAAA,cAAChD,MAAMiD,SAAO,IAAA,GACd,sBAAA,cAACjD,MAAMkD,WAAS,MACd,sBAAA,cAAClD,MAAMmD,UAAQ;MAACH,YAAW;OACzB,sBAAA,cAAChD,MAAMoD,UAAQ,IAAA,GACf,sBAAA,cAACpD,MAAM8C,SAAO,MACXtC,OAAOC,IAAI,CAAC4C,MAAMC,UACjB,sBAAA,cAACtD,MAAMuD,MAAI;MAACF;MAAYG,KAAKF;MAAO3B,QAAQvB,MAAMuB,QAAQC,MAAMyB,KAAKxB,EAAE,KAAK;QAAEd,GAAG;QAAGC,GAAG;MAAE;OACvF,sBAAA,cAACxB,SAAAA;MAAQiE,MAAK;MAAkBC,MAAM;QAAEC,SAASN;MAAK;MAAGO,OAAO;;;;;AASlF;",
6
+ "names": ["React", "useCallback", "useRef", "Surface", "createIntent", "useIntentDispatcher", "getSpace", "Ref", "invariant", "SpaceAction", "useSignalsMemo", "Board", "StackItem", "isNonNullable", "BoardContainer", "board", "dispatchPromise", "dispatch", "controller", "items", "map", "ref", "target", "filter", "handleAdd", "position", "x", "y", "space", "OpenCreateObject", "navigable", "onCreateObject", "object", "push", "make", "console", "log", "length", "layout", "cells", "id", "width", "height", "current", "center", "handleDelete", "idx", "findIndex", "dxn", "asEchoDXN", "echoId", "splice", "handleMove", "Root", "onAdd", "onDelete", "onMove", "Content", "toolbar", "classNames", "Toolbar", "Container", "Viewport", "Backdrop", "item", "index", "Cell", "key", "role", "data", "subject", "limit"]
7
+ }
@@ -0,0 +1,91 @@
1
+ import {
2
+ BoardContainer
3
+ } from "./chunk-YYCPOFRP.mjs";
4
+ import {
5
+ Board_exports,
6
+ meta
7
+ } from "./chunk-V67SBM4U.mjs";
8
+
9
+ // src/BoardPlugin.tsx
10
+ import { Capabilities, Events, contributes, createIntent, defineModule, definePlugin } from "@dxos/app-framework";
11
+ import { ClientEvents } from "@dxos/plugin-client";
12
+ import { SpaceCapabilities } from "@dxos/plugin-space";
13
+ import { defineObjectForm } from "@dxos/plugin-space/types";
14
+ import { translations as boardTranslations } from "@dxos/react-ui-board";
15
+
16
+ // src/capabilities/index.ts
17
+ import { lazy } from "@dxos/app-framework";
18
+ var IntentResolver = lazy(() => import("./intent-resolver-AHP36LHF.mjs"));
19
+ var ReactSurface = lazy(() => import("./react-surface-NRTYEQIC.mjs"));
20
+
21
+ // src/translations.ts
22
+ var translations = [
23
+ {
24
+ "en-US": {
25
+ [Board_exports.Board.typename]: {
26
+ "typename label": "Board",
27
+ "typename label_zero": "Boards",
28
+ "typename label_one": "Board",
29
+ "typename label_other": "Boards",
30
+ "object name placeholder": "New board",
31
+ "rename object label": "Rename board",
32
+ "delete object label": "Delete board"
33
+ },
34
+ [meta.id]: {
35
+ "plugin name": "Board"
36
+ }
37
+ }
38
+ }
39
+ ];
40
+
41
+ // src/BoardPlugin.tsx
42
+ var BoardPlugin = () => {
43
+ return definePlugin(meta, [
44
+ defineModule({
45
+ id: `${meta.id}/module/translations`,
46
+ activatesOn: Events.SetupTranslations,
47
+ activate: () => contributes(Capabilities.Translations, [
48
+ ...translations,
49
+ ...boardTranslations
50
+ ])
51
+ }),
52
+ defineModule({
53
+ id: `${meta.id}/module/metadata`,
54
+ activatesOn: Events.SetupMetadata,
55
+ activate: () => (
56
+ // TODO(burdon): "Metadata" here seems non-descriptive; is this specifically for the type? ObjectMetadata?
57
+ contributes(Capabilities.Metadata, {
58
+ id: Board_exports.Board.typename,
59
+ metadata: {
60
+ icon: "ph--squares-four--regular"
61
+ }
62
+ })
63
+ )
64
+ }),
65
+ defineModule({
66
+ id: `${meta.id}/module/object-form`,
67
+ activatesOn: ClientEvents.SetupSchema,
68
+ activate: () => contributes(SpaceCapabilities.ObjectForm, defineObjectForm({
69
+ objectSchema: Board_exports.Board,
70
+ getIntent: () => createIntent(Board_exports.Create)
71
+ }))
72
+ }),
73
+ defineModule({
74
+ id: `${meta.id}/module/react-surface`,
75
+ activatesOn: Events.SetupReactSurface,
76
+ activate: ReactSurface
77
+ }),
78
+ defineModule({
79
+ id: `${meta.id}/module/intent-resolver`,
80
+ activatesOn: Events.SetupIntentResolver,
81
+ activate: IntentResolver
82
+ })
83
+ ]);
84
+ };
85
+ export {
86
+ Board_exports as Board,
87
+ BoardContainer,
88
+ BoardPlugin,
89
+ meta
90
+ };
91
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/BoardPlugin.tsx", "../../../src/capabilities/index.ts", "../../../src/translations.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { Capabilities, Events, contributes, createIntent, defineModule, definePlugin } from '@dxos/app-framework';\nimport { ClientEvents } from '@dxos/plugin-client';\nimport { SpaceCapabilities } from '@dxos/plugin-space';\nimport { defineObjectForm } from '@dxos/plugin-space/types';\nimport { translations as boardTranslations } from '@dxos/react-ui-board';\n\nimport { IntentResolver, ReactSurface } from './capabilities';\nimport { meta } from './meta';\nimport { translations } from './translations';\nimport { Board } from './types';\n\nexport const BoardPlugin = () => {\n return definePlugin(meta, [\n defineModule({\n id: `${meta.id}/module/translations`,\n activatesOn: Events.SetupTranslations,\n activate: () => contributes(Capabilities.Translations, [...translations, ...boardTranslations]),\n }),\n defineModule({\n id: `${meta.id}/module/metadata`,\n activatesOn: Events.SetupMetadata,\n activate: () =>\n // TODO(burdon): \"Metadata\" here seems non-descriptive; is this specifically for the type? ObjectMetadata?\n contributes(Capabilities.Metadata, {\n id: Board.Board.typename,\n metadata: {\n icon: 'ph--squares-four--regular',\n },\n }),\n }),\n defineModule({\n id: `${meta.id}/module/object-form`,\n activatesOn: ClientEvents.SetupSchema,\n activate: () =>\n contributes(\n SpaceCapabilities.ObjectForm,\n defineObjectForm({\n objectSchema: Board.Board,\n getIntent: () => createIntent(Board.Create),\n }),\n ),\n }),\n defineModule({\n id: `${meta.id}/module/react-surface`,\n activatesOn: Events.SetupReactSurface,\n activate: ReactSurface,\n }),\n defineModule({\n id: `${meta.id}/module/intent-resolver`,\n activatesOn: Events.SetupIntentResolver,\n activate: IntentResolver,\n }),\n ]);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { lazy } from '@dxos/app-framework';\n\nexport const IntentResolver = lazy(() => import('./intent-resolver'));\nexport const ReactSurface = lazy(() => import('./react-surface'));\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Resource } from '@dxos/react-ui';\n\nimport { meta } from './meta';\nimport { Board } from './types';\n\nexport const translations = [\n {\n 'en-US': {\n [Board.Board.typename]: {\n 'typename label': 'Board',\n 'typename label_zero': 'Boards',\n 'typename label_one': 'Board',\n 'typename label_other': 'Boards',\n 'object name placeholder': 'New board',\n 'rename object label': 'Rename board',\n 'delete object label': 'Delete board',\n },\n [meta.id]: {\n 'plugin name': 'Board',\n },\n },\n },\n] as const satisfies Resource[];\n"],
5
+ "mappings": ";;;;;;;;;AAIA,SAASA,cAAcC,QAAQC,aAAaC,cAAcC,cAAcC,oBAAoB;AAC5F,SAASC,oBAAoB;AAC7B,SAASC,yBAAyB;AAClC,SAASC,wBAAwB;AACjC,SAASC,gBAAgBC,yBAAyB;;;ACJlD,SAASC,YAAY;AAEd,IAAMC,iBAAiBC,KAAK,MAAM,OAAO,gCAAA,CAAA;AACzC,IAAMC,eAAeD,KAAK,MAAM,OAAO,8BAAA,CAAA;;;ACEvC,IAAME,eAAe;EAC1B;IACE,SAAS;MACP,CAACC,cAAMA,MAAMC,QAAQ,GAAG;QACtB,kBAAkB;QAClB,uBAAuB;QACvB,sBAAsB;QACtB,wBAAwB;QACxB,2BAA2B;QAC3B,uBAAuB;QACvB,uBAAuB;MACzB;MACA,CAACC,KAAKC,EAAE,GAAG;QACT,eAAe;MACjB;IACF;EACF;;;;AFVK,IAAMC,cAAc,MAAA;AACzB,SAAOC,aAAaC,MAAM;IACxBC,aAAa;MACXC,IAAI,GAAGF,KAAKE,EAAE;MACdC,aAAaC,OAAOC;MACpBC,UAAU,MAAMC,YAAYC,aAAaC,cAAc;WAAIC;WAAiBC;OAAkB;IAChG,CAAA;IACAV,aAAa;MACXC,IAAI,GAAGF,KAAKE,EAAE;MACdC,aAAaC,OAAOQ;MACpBN,UAAU;;QAERC,YAAYC,aAAaK,UAAU;UACjCX,IAAIY,cAAMA,MAAMC;UAChBC,UAAU;YACRC,MAAM;UACR;QACF,CAAA;;IACJ,CAAA;IACAhB,aAAa;MACXC,IAAI,GAAGF,KAAKE,EAAE;MACdC,aAAae,aAAaC;MAC1Bb,UAAU,MACRC,YACEa,kBAAkBC,YAClBC,iBAAiB;QACfC,cAAcT,cAAMA;QACpBU,WAAW,MAAMC,aAAaX,cAAMY,MAAM;MAC5C,CAAA,CAAA;IAEN,CAAA;IACAzB,aAAa;MACXC,IAAI,GAAGF,KAAKE,EAAE;MACdC,aAAaC,OAAOuB;MACpBrB,UAAUsB;IACZ,CAAA;IACA3B,aAAa;MACXC,IAAI,GAAGF,KAAKE,EAAE;MACdC,aAAaC,OAAOyB;MACpBvB,UAAUwB;IACZ,CAAA;GACD;AACH;",
6
+ "names": ["Capabilities", "Events", "contributes", "createIntent", "defineModule", "definePlugin", "ClientEvents", "SpaceCapabilities", "defineObjectForm", "translations", "boardTranslations", "lazy", "IntentResolver", "lazy", "ReactSurface", "translations", "Board", "typename", "meta", "id", "BoardPlugin", "definePlugin", "meta", "defineModule", "id", "activatesOn", "Events", "SetupTranslations", "activate", "contributes", "Capabilities", "Translations", "translations", "boardTranslations", "SetupMetadata", "Metadata", "Board", "typename", "metadata", "icon", "ClientEvents", "SetupSchema", "SpaceCapabilities", "ObjectForm", "defineObjectForm", "objectSchema", "getIntent", "createIntent", "Create", "SetupReactSurface", "ReactSurface", "SetupIntentResolver", "IntentResolver"]
7
+ }
@@ -0,0 +1,33 @@
1
+ import {
2
+ Board_exports
3
+ } from "./chunk-V67SBM4U.mjs";
4
+
5
+ // src/capabilities/intent-resolver.ts
6
+ import { Capabilities, contributes, createResolver } from "@dxos/app-framework";
7
+ import { Obj } from "@dxos/echo";
8
+ var intent_resolver_default = (() => [
9
+ contributes(Capabilities.IntentResolver, createResolver({
10
+ intent: Board_exports.Create,
11
+ resolve: ({ name }) => {
12
+ return {
13
+ data: {
14
+ object: Obj.make(Board_exports.Board, {
15
+ name,
16
+ items: [],
17
+ layout: {
18
+ size: {
19
+ width: 5,
20
+ height: 5
21
+ },
22
+ cells: {}
23
+ }
24
+ })
25
+ }
26
+ };
27
+ }
28
+ }))
29
+ ]);
30
+ export {
31
+ intent_resolver_default as default
32
+ };
33
+ //# sourceMappingURL=intent-resolver-AHP36LHF.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/intent-resolver.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capabilities, contributes, createResolver } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\n\nimport { Board } from '../types';\n\nexport default () => [\n contributes(\n Capabilities.IntentResolver,\n createResolver({\n intent: Board.Create,\n resolve: ({ name }) => {\n return {\n data: {\n object: Obj.make(Board.Board, {\n name,\n items: [],\n layout: {\n size: {\n width: 5,\n height: 5,\n },\n cells: {},\n },\n }),\n },\n };\n },\n }),\n ),\n];\n"],
5
+ "mappings": ";;;;;AAIA,SAASA,cAAcC,aAAaC,sBAAsB;AAC1D,SAASC,WAAW;AAIpB,IAAA,2BAAe,MAAM;EACnBC,YACEC,aAAaC,gBACbC,eAAe;IACbC,QAAQC,cAAMC;IACdC,SAAS,CAAC,EAAEC,KAAI,MAAE;AAChB,aAAO;QACLC,MAAM;UACJC,QAAQC,IAAIC,KAAKP,cAAMA,OAAO;YAC5BG;YACAK,OAAO,CAAA;YACPC,QAAQ;cACNC,MAAM;gBACJC,OAAO;gBACPC,QAAQ;cACV;cACAC,OAAO,CAAC;YACV;UACF,CAAA;QACF;MACF;IACF;EACF,CAAA,CAAA;;",
6
+ "names": ["Capabilities", "contributes", "createResolver", "Obj", "contributes", "Capabilities", "IntentResolver", "createResolver", "intent", "Board", "Create", "resolve", "name", "data", "object", "Obj", "make", "items", "layout", "size", "width", "height", "cells"]
7
+ }
@@ -0,0 +1 @@
1
+ {"inputs":{"src/components/BoardContainer.tsx":{"bytes":12278,"imports":[{"path":"@preact-signals/safe-react/tracking","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/client/echo","kind":"import-statement","external":true},{"path":"@dxos/echo","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/plugin-space/types","kind":"import-statement","external":true},{"path":"@dxos/react-ui","kind":"import-statement","external":true},{"path":"@dxos/react-ui-board","kind":"import-statement","external":true},{"path":"@dxos/react-ui-stack","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"format":"esm"},"src/components/index.ts":{"bytes":485,"imports":[{"path":"src/components/BoardContainer.tsx","kind":"import-statement","original":"./BoardContainer"}],"format":"esm"},"src/meta.ts":{"bytes":1492,"imports":[],"format":"esm"},"src/types/Board.ts":{"bytes":4227,"imports":[{"path":"effect","kind":"import-statement","external":true},{"path":"@dxos/echo","kind":"import-statement","external":true},{"path":"@dxos/echo-schema","kind":"import-statement","external":true},{"path":"@dxos/react-ui-board","kind":"import-statement","external":true},{"path":"src/meta.ts","kind":"import-statement","original":"../meta"}],"format":"esm"},"src/types/index.ts":{"bytes":508,"imports":[{"path":"src/types/Board.ts","kind":"import-statement","original":"./Board"}],"format":"esm"},"src/capabilities/intent-resolver.ts":{"bytes":3014,"imports":[{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/echo","kind":"import-statement","external":true},{"path":"src/types/index.ts","kind":"import-statement","original":"../types"}],"format":"esm"},"src/capabilities/react-surface.tsx":{"bytes":2913,"imports":[{"path":"react","kind":"import-statement","external":true},{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/echo","kind":"import-statement","external":true},{"path":"src/components/index.ts","kind":"import-statement","original":"../components"},{"path":"src/meta.ts","kind":"import-statement","original":"../meta"},{"path":"src/types/index.ts","kind":"import-statement","original":"../types"}],"format":"esm"},"src/capabilities/index.ts":{"bytes":1035,"imports":[{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"src/capabilities/intent-resolver.ts","kind":"dynamic-import","original":"./intent-resolver"},{"path":"src/capabilities/react-surface.tsx","kind":"dynamic-import","original":"./react-surface"}],"format":"esm"},"src/translations.ts":{"bytes":2322,"imports":[{"path":"src/meta.ts","kind":"import-statement","original":"./meta"},{"path":"src/types/index.ts","kind":"import-statement","original":"./types"}],"format":"esm"},"src/BoardPlugin.tsx":{"bytes":7274,"imports":[{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/plugin-client","kind":"import-statement","external":true},{"path":"@dxos/plugin-space","kind":"import-statement","external":true},{"path":"@dxos/plugin-space/types","kind":"import-statement","external":true},{"path":"@dxos/react-ui-board","kind":"import-statement","external":true},{"path":"src/capabilities/index.ts","kind":"import-statement","original":"./capabilities"},{"path":"src/meta.ts","kind":"import-statement","original":"./meta"},{"path":"src/translations.ts","kind":"import-statement","original":"./translations"},{"path":"src/types/index.ts","kind":"import-statement","original":"./types"}],"format":"esm"},"src/index.ts":{"bytes":722,"imports":[{"path":"src/components/index.ts","kind":"import-statement","original":"./components"},{"path":"src/meta.ts","kind":"import-statement","original":"./meta"},{"path":"src/types/index.ts","kind":"import-statement","original":"./types"},{"path":"src/BoardPlugin.tsx","kind":"import-statement","original":"./BoardPlugin"}],"format":"esm"}},"outputs":{"dist/lib/browser/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":5025},"dist/lib/browser/index.mjs":{"imports":[{"path":"dist/lib/browser/chunk-YYCPOFRP.mjs","kind":"import-statement"},{"path":"dist/lib/browser/chunk-V67SBM4U.mjs","kind":"import-statement"},{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/plugin-client","kind":"import-statement","external":true},{"path":"@dxos/plugin-space","kind":"import-statement","external":true},{"path":"@dxos/plugin-space/types","kind":"import-statement","external":true},{"path":"@dxos/react-ui-board","kind":"import-statement","external":true},{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"dist/lib/browser/intent-resolver-AHP36LHF.mjs","kind":"dynamic-import"},{"path":"dist/lib/browser/react-surface-NRTYEQIC.mjs","kind":"dynamic-import"}],"exports":["Board","BoardContainer","BoardPlugin","meta"],"entryPoint":"src/index.ts","inputs":{"src/index.ts":{"bytesInOutput":0},"src/BoardPlugin.tsx":{"bytesInOutput":1708},"src/capabilities/index.ts":{"bytesInOutput":190},"src/translations.ts":{"bytesInOutput":458}},"bytes":2692},"dist/lib/browser/types/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":93},"dist/lib/browser/types/index.mjs":{"imports":[{"path":"dist/lib/browser/chunk-V67SBM4U.mjs","kind":"import-statement"}],"exports":["Board"],"entryPoint":"src/types/index.ts","inputs":{},"bytes":129},"dist/lib/browser/intent-resolver-AHP36LHF.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":1473},"dist/lib/browser/intent-resolver-AHP36LHF.mjs":{"imports":[{"path":"dist/lib/browser/chunk-V67SBM4U.mjs","kind":"import-statement"},{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/echo","kind":"import-statement","external":true}],"exports":["default"],"entryPoint":"src/capabilities/intent-resolver.ts","inputs":{"src/capabilities/intent-resolver.ts":{"bytesInOutput":598}},"bytes":797},"dist/lib/browser/react-surface-NRTYEQIC.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":1429},"dist/lib/browser/react-surface-NRTYEQIC.mjs":{"imports":[{"path":"dist/lib/browser/chunk-YYCPOFRP.mjs","kind":"import-statement"},{"path":"dist/lib/browser/chunk-V67SBM4U.mjs","kind":"import-statement"},{"path":"react","kind":"import-statement","external":true},{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/echo","kind":"import-statement","external":true}],"exports":["default"],"entryPoint":"src/capabilities/react-surface.tsx","inputs":{"src/capabilities/react-surface.tsx":{"bytesInOutput":528}},"bytes":787},"dist/lib/browser/chunk-YYCPOFRP.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":6054},"dist/lib/browser/chunk-YYCPOFRP.mjs":{"imports":[{"path":"@preact-signals/safe-react/tracking","kind":"import-statement","external":true},{"path":"react","kind":"import-statement","external":true},{"path":"@dxos/app-framework","kind":"import-statement","external":true},{"path":"@dxos/client/echo","kind":"import-statement","external":true},{"path":"@dxos/echo","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/plugin-space/types","kind":"import-statement","external":true},{"path":"@dxos/react-ui","kind":"import-statement","external":true},{"path":"@dxos/react-ui-board","kind":"import-statement","external":true},{"path":"@dxos/react-ui-stack","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"exports":["BoardContainer"],"inputs":{"src/components/BoardContainer.tsx":{"bytesInOutput":3280},"src/components/index.ts":{"bytesInOutput":0}},"bytes":3391},"dist/lib/browser/chunk-V67SBM4U.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":2961},"dist/lib/browser/chunk-V67SBM4U.mjs":{"imports":[{"path":"effect","kind":"import-statement","external":true},{"path":"@dxos/echo","kind":"import-statement","external":true},{"path":"@dxos/echo-schema","kind":"import-statement","external":true},{"path":"@dxos/react-ui-board","kind":"import-statement","external":true}],"exports":["Board_exports","meta"],"inputs":{"src/types/Board.ts":{"bytesInOutput":914},"src/meta.ts":{"bytesInOutput":324},"src/types/index.ts":{"bytesInOutput":0}},"bytes":1548}}}
@@ -0,0 +1,30 @@
1
+ import {
2
+ BoardContainer
3
+ } from "./chunk-YYCPOFRP.mjs";
4
+ import {
5
+ Board_exports,
6
+ meta
7
+ } from "./chunk-V67SBM4U.mjs";
8
+
9
+ // src/capabilities/react-surface.tsx
10
+ import React from "react";
11
+ import { Capabilities, contributes, createSurface } from "@dxos/app-framework";
12
+ import { Obj } from "@dxos/echo";
13
+ var react_surface_default = ((context) => contributes(Capabilities.ReactSurface, [
14
+ createSurface({
15
+ id: meta.id,
16
+ role: [
17
+ "article",
18
+ "section"
19
+ ],
20
+ filter: (data) => Obj.instanceOf(Board_exports.Board, data.subject),
21
+ component: ({ data, role }) => /* @__PURE__ */ React.createElement(BoardContainer, {
22
+ board: data.subject,
23
+ role
24
+ })
25
+ })
26
+ ]));
27
+ export {
28
+ react_surface_default as default
29
+ };
30
+ //# sourceMappingURL=react-surface-NRTYEQIC.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/react-surface.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Capabilities, type PluginContext, contributes, createSurface } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\n\nimport { BoardContainer } from '../components';\nimport { meta } from '../meta';\nimport { Board } from '../types';\n\nexport default (context: PluginContext) =>\n contributes(Capabilities.ReactSurface, [\n createSurface({\n id: meta.id,\n role: ['article', 'section'],\n filter: (data): data is { subject: Board.Board } => Obj.instanceOf(Board.Board, data.subject),\n component: ({ data, role }) => <BoardContainer board={data.subject} role={role} />,\n }),\n ]);\n"],
5
+ "mappings": ";;;;;;;;;AAIA,OAAOA,WAAW;AAElB,SAASC,cAAkCC,aAAaC,qBAAqB;AAC7E,SAASC,WAAW;AAMpB,IAAA,yBAAe,CAACC,YACdC,YAAYC,aAAaC,cAAc;EACrCC,cAAc;IACZC,IAAIC,KAAKD;IACTE,MAAM;MAAC;MAAW;;IAClBC,QAAQ,CAACC,SAA2CC,IAAIC,WAAWC,cAAMA,OAAOH,KAAKI,OAAO;IAC5FC,WAAW,CAAC,EAAEL,MAAMF,KAAI,MAAO,sBAAA,cAACQ,gBAAAA;MAAeC,OAAOP,KAAKI;MAASN;;EACtE,CAAA;CACD;",
6
+ "names": ["React", "Capabilities", "contributes", "createSurface", "Obj", "context", "contributes", "Capabilities", "ReactSurface", "createSurface", "id", "meta", "role", "filter", "data", "Obj", "instanceOf", "Board", "subject", "component", "BoardContainer", "board"]
7
+ }
@@ -0,0 +1,7 @@
1
+ import {
2
+ Board_exports
3
+ } from "../chunk-V67SBM4U.mjs";
4
+ export {
5
+ Board_exports as Board
6
+ };
7
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": [],
4
+ "sourcesContent": [],
5
+ "mappings": "",
6
+ "names": []
7
+ }
@@ -0,0 +1,108 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+
3
+ // src/components/BoardContainer.tsx
4
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
5
+ import React, { useCallback, useRef } from "react";
6
+ import { Surface, createIntent, useIntentDispatcher } from "@dxos/app-framework";
7
+ import { getSpace } from "@dxos/client/echo";
8
+ import { Ref } from "@dxos/echo";
9
+ import { invariant } from "@dxos/invariant";
10
+ import { SpaceAction } from "@dxos/plugin-space/types";
11
+ import { useSignalsMemo } from "@dxos/react-ui";
12
+ import { Board } from "@dxos/react-ui-board";
13
+ import { StackItem } from "@dxos/react-ui-stack";
14
+ import { isNonNullable } from "@dxos/util";
15
+ var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-board/src/components/BoardContainer.tsx";
16
+ var BoardContainer = ({ board }) => {
17
+ var _effect = _useSignals();
18
+ try {
19
+ const { dispatchPromise: dispatch } = useIntentDispatcher();
20
+ const controller = useRef(null);
21
+ const items = useSignalsMemo(() => board.items.map((ref) => ref.target).filter(isNonNullable), [
22
+ board
23
+ ]);
24
+ const handleAdd = useCallback(async (position = {
25
+ x: 0,
26
+ y: 0
27
+ }) => {
28
+ const space = getSpace(board);
29
+ invariant(space, void 0, {
30
+ F: __dxlog_file,
31
+ L: 32,
32
+ S: void 0,
33
+ A: [
34
+ "space",
35
+ ""
36
+ ]
37
+ });
38
+ await dispatch(createIntent(SpaceAction.OpenCreateObject, {
39
+ target: space,
40
+ navigable: false,
41
+ onCreateObject: (object) => {
42
+ board.items.push(Ref.make(object));
43
+ console.log(board.items.length);
44
+ board.layout.cells[object.id] = {
45
+ ...position,
46
+ width: 1,
47
+ height: 1
48
+ };
49
+ controller.current?.center(position);
50
+ }
51
+ }));
52
+ }, [
53
+ board,
54
+ controller,
55
+ dispatch
56
+ ]);
57
+ const handleDelete = useCallback((id) => {
58
+ const idx = board.items.findIndex((ref) => ref.dxn.asEchoDXN()?.echoId === id);
59
+ if (idx !== -1) {
60
+ board.items.splice(idx, 1);
61
+ }
62
+ delete board.layout.cells[id];
63
+ }, [
64
+ board
65
+ ]);
66
+ const handleMove = useCallback((id, position) => {
67
+ const layout = board.layout.cells[id];
68
+ board.layout.cells[id] = {
69
+ ...layout,
70
+ ...position
71
+ };
72
+ }, [
73
+ board
74
+ ]);
75
+ return /* @__PURE__ */ React.createElement(Board.Root, {
76
+ ref: controller,
77
+ layout: board.layout,
78
+ onAdd: handleAdd,
79
+ onDelete: handleDelete,
80
+ onMove: handleMove
81
+ }, /* @__PURE__ */ React.createElement(StackItem.Content, {
82
+ toolbar: true,
83
+ classNames: "overflow-hidden"
84
+ }, /* @__PURE__ */ React.createElement(Board.Toolbar, null), /* @__PURE__ */ React.createElement(Board.Container, null, /* @__PURE__ */ React.createElement(Board.Viewport, {
85
+ classNames: "border-none"
86
+ }, /* @__PURE__ */ React.createElement(Board.Backdrop, null), /* @__PURE__ */ React.createElement(Board.Content, null, items?.map((item, index) => /* @__PURE__ */ React.createElement(Board.Cell, {
87
+ item,
88
+ key: index,
89
+ layout: board.layout?.cells[item.id] ?? {
90
+ x: 0,
91
+ y: 0
92
+ }
93
+ }, /* @__PURE__ */ React.createElement(Surface, {
94
+ role: "card--extrinsic",
95
+ data: {
96
+ subject: item
97
+ },
98
+ limit: 1
99
+ }))))))));
100
+ } finally {
101
+ _effect.f();
102
+ }
103
+ };
104
+
105
+ export {
106
+ BoardContainer
107
+ };
108
+ //# sourceMappingURL=chunk-RNEIWFZQ.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/BoardContainer.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useCallback, useRef } from 'react';\n\nimport { Surface, createIntent, useIntentDispatcher } from '@dxos/app-framework';\nimport { getSpace } from '@dxos/client/echo';\nimport { type Obj, Ref } from '@dxos/echo';\nimport { invariant } from '@dxos/invariant';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { useSignalsMemo } from '@dxos/react-ui';\nimport { Board, type BoardController, type BoardRootProps } from '@dxos/react-ui-board';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { isNonNullable } from '@dxos/util';\n\nimport { type Board as BoardType } from '../types';\n\nexport type BoardContainerProps = {\n role?: string;\n board: BoardType.Board;\n};\n\nexport const BoardContainer = ({ board }: BoardContainerProps) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const controller = useRef<BoardController>(null);\n const items = useSignalsMemo(() => board.items.map((ref) => ref.target).filter(isNonNullable), [board]);\n\n const handleAdd = useCallback<NonNullable<BoardRootProps['onAdd']>>(\n async (position = { x: 0, y: 0 }) => {\n const space = getSpace(board);\n invariant(space);\n await dispatch(\n createIntent(SpaceAction.OpenCreateObject, {\n target: space,\n navigable: false,\n onCreateObject: (object: Obj.Any) => {\n board.items.push(Ref.make(object));\n console.log(board.items.length);\n board.layout.cells[object.id] = { ...position, width: 1, height: 1 };\n controller.current?.center(position);\n },\n }),\n );\n },\n [board, controller, dispatch],\n );\n\n // TODO(burdon): Use intents so can be undone.\n const handleDelete = useCallback<NonNullable<BoardRootProps['onDelete']>>(\n (id) => {\n // TODO(burdon): Impl. DXN.equals and pass in DXN from `id`.\n const idx = board.items.findIndex((ref) => ref.dxn.asEchoDXN()?.echoId === id);\n if (idx !== -1) {\n board.items.splice(idx, 1);\n }\n delete board.layout.cells[id];\n },\n [board],\n );\n\n const handleMove = useCallback<NonNullable<BoardRootProps['onMove']>>(\n (id, position) => {\n const layout = board.layout.cells[id];\n board.layout.cells[id] = { ...layout, ...position };\n },\n [board],\n );\n\n return (\n <Board.Root ref={controller} layout={board.layout} onAdd={handleAdd} onDelete={handleDelete} onMove={handleMove}>\n <StackItem.Content toolbar classNames='overflow-hidden'>\n <Board.Toolbar />\n <Board.Container>\n <Board.Viewport classNames='border-none'>\n <Board.Backdrop />\n <Board.Content>\n {items?.map((item, index) => (\n <Board.Cell item={item} key={index} layout={board.layout?.cells[item.id] ?? { x: 0, y: 0 }}>\n <Surface role='card--extrinsic' data={{ subject: item }} limit={1} />\n </Board.Cell>\n ))}\n </Board.Content>\n </Board.Viewport>\n </Board.Container>\n </StackItem.Content>\n </Board.Root>\n );\n};\n"],
5
+ "mappings": ";;;;AAIA,OAAOA,SAASC,aAAaC,cAAc;AAE3C,SAASC,SAASC,cAAcC,2BAA2B;AAC3D,SAASC,gBAAgB;AACzB,SAAmBC,WAAW;AAC9B,SAASC,iBAAiB;AAC1B,SAASC,mBAAmB;AAC5B,SAASC,sBAAsB;AAC/B,SAASC,aAAwD;AACjE,SAASC,iBAAiB;AAC1B,SAASC,qBAAqB;;AASvB,IAAMC,iBAAiB,CAAC,EAAEC,MAAK,MAAuB;;;AAC3D,UAAM,EAAEC,iBAAiBC,SAAQ,IAAKZ,oBAAAA;AACtC,UAAMa,aAAahB,OAAwB,IAAA;AAC3C,UAAMiB,QAAQT,eAAe,MAAMK,MAAMI,MAAMC,IAAI,CAACC,QAAQA,IAAIC,MAAM,EAAEC,OAAOV,aAAAA,GAAgB;MAACE;KAAM;AAEtG,UAAMS,YAAYvB,YAChB,OAAOwB,WAAW;MAAEC,GAAG;MAAGC,GAAG;IAAE,MAAC;AAC9B,YAAMC,QAAQtB,SAASS,KAAAA;AACvBP,gBAAUoB,OAAAA,QAAAA;;;;;;;;;AACV,YAAMX,SACJb,aAAaK,YAAYoB,kBAAkB;QACzCP,QAAQM;QACRE,WAAW;QACXC,gBAAgB,CAACC,WAAAA;AACfjB,gBAAMI,MAAMc,KAAK1B,IAAI2B,KAAKF,MAAAA,CAAAA;AAC1BG,kBAAQC,IAAIrB,MAAMI,MAAMkB,MAAM;AAC9BtB,gBAAMuB,OAAOC,MAAMP,OAAOQ,EAAE,IAAI;YAAE,GAAGf;YAAUgB,OAAO;YAAGC,QAAQ;UAAE;AACnExB,qBAAWyB,SAASC,OAAOnB,QAAAA;QAC7B;MACF,CAAA,CAAA;IAEJ,GACA;MAACV;MAAOG;MAAYD;KAAS;AAI/B,UAAM4B,eAAe5C,YACnB,CAACuC,OAAAA;AAEC,YAAMM,MAAM/B,MAAMI,MAAM4B,UAAU,CAAC1B,QAAQA,IAAI2B,IAAIC,UAAS,GAAIC,WAAWV,EAAAA;AAC3E,UAAIM,QAAQ,IAAI;AACd/B,cAAMI,MAAMgC,OAAOL,KAAK,CAAA;MAC1B;AACA,aAAO/B,MAAMuB,OAAOC,MAAMC,EAAAA;IAC5B,GACA;MAACzB;KAAM;AAGT,UAAMqC,aAAanD,YACjB,CAACuC,IAAIf,aAAAA;AACH,YAAMa,SAASvB,MAAMuB,OAAOC,MAAMC,EAAAA;AAClCzB,YAAMuB,OAAOC,MAAMC,EAAAA,IAAM;QAAE,GAAGF;QAAQ,GAAGb;MAAS;IACpD,GACA;MAACV;KAAM;AAGT,WACE,sBAAA,cAACJ,MAAM0C,MAAI;MAAChC,KAAKH;MAAYoB,QAAQvB,MAAMuB;MAAQgB,OAAO9B;MAAW+B,UAAUV;MAAcW,QAAQJ;OACnG,sBAAA,cAACxC,UAAU6C,SAAO;MAACC,SAAAA;MAAQC,YAAW;OACpC,sBAAA,cAAChD,MAAMiD,SAAO,IAAA,GACd,sBAAA,cAACjD,MAAMkD,WAAS,MACd,sBAAA,cAAClD,MAAMmD,UAAQ;MAACH,YAAW;OACzB,sBAAA,cAAChD,MAAMoD,UAAQ,IAAA,GACf,sBAAA,cAACpD,MAAM8C,SAAO,MACXtC,OAAOC,IAAI,CAAC4C,MAAMC,UACjB,sBAAA,cAACtD,MAAMuD,MAAI;MAACF;MAAYG,KAAKF;MAAO3B,QAAQvB,MAAMuB,QAAQC,MAAMyB,KAAKxB,EAAE,KAAK;QAAEd,GAAG;QAAGC,GAAG;MAAE;OACvF,sBAAA,cAACxB,SAAAA;MAAQiE,MAAK;MAAkBC,MAAM;QAAEC,SAASN;MAAK;MAAGO,OAAO;;;;;AASlF;",
6
+ "names": ["React", "useCallback", "useRef", "Surface", "createIntent", "useIntentDispatcher", "getSpace", "Ref", "invariant", "SpaceAction", "useSignalsMemo", "Board", "StackItem", "isNonNullable", "BoardContainer", "board", "dispatchPromise", "dispatch", "controller", "items", "map", "ref", "target", "filter", "handleAdd", "position", "x", "y", "space", "OpenCreateObject", "navigable", "onCreateObject", "object", "push", "make", "console", "log", "length", "layout", "cells", "id", "width", "height", "current", "center", "handleDelete", "idx", "findIndex", "dxn", "asEchoDXN", "echoId", "splice", "handleMove", "Root", "onAdd", "onDelete", "onMove", "Content", "toolbar", "classNames", "Toolbar", "Container", "Viewport", "Backdrop", "item", "index", "Cell", "key", "role", "data", "subject", "limit"]
7
+ }