@dxos/plugin-space 0.8.4-main.c1de068 → 0.8.4-main.e098934

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 (218) hide show
  1. package/dist/lib/browser/{ObjectDetailsPanel-YPTDQKMG.mjs → ObjectDetailsPanel-J7KGPJJK.mjs} +7 -5
  2. package/dist/lib/browser/ObjectDetailsPanel-J7KGPJJK.mjs.map +7 -0
  3. package/dist/lib/browser/RecordMain-TEBGAVSL.mjs +68 -0
  4. package/dist/lib/browser/RecordMain-TEBGAVSL.mjs.map +7 -0
  5. package/dist/lib/browser/{app-graph-builder-7CZZJS3S.mjs → app-graph-builder-AFC6PNAB.mjs} +57 -19
  6. package/dist/lib/browser/app-graph-builder-AFC6PNAB.mjs.map +7 -0
  7. package/dist/lib/browser/{app-graph-serializer-H6AW7KGS.mjs → app-graph-serializer-Q7QG4EKW.mjs} +4 -4
  8. package/dist/lib/browser/{chunk-V7MJSSBQ.mjs → chunk-6GRF7NEF.mjs} +100 -104
  9. package/dist/lib/browser/chunk-6GRF7NEF.mjs.map +7 -0
  10. package/dist/lib/browser/{chunk-JS3MMC42.mjs → chunk-CBYL62HG.mjs} +2 -2
  11. package/dist/lib/{node-esm/chunk-5HHYE264.mjs.map → browser/chunk-CBYL62HG.mjs.map} +3 -3
  12. package/dist/lib/browser/{chunk-VLBRSGJ2.mjs → chunk-ELJDGQTO.mjs} +3 -3
  13. package/dist/lib/browser/{chunk-VLBRSGJ2.mjs.map → chunk-ELJDGQTO.mjs.map} +3 -3
  14. package/dist/lib/browser/{chunk-XUYKJUU7.mjs → chunk-S33AYKSS.mjs} +68 -16
  15. package/dist/lib/browser/chunk-S33AYKSS.mjs.map +7 -0
  16. package/dist/lib/browser/{chunk-CEFHNVU7.mjs → chunk-TUQZO5P4.mjs} +1 -1
  17. package/dist/lib/browser/{chunk-CEFHNVU7.mjs.map → chunk-TUQZO5P4.mjs.map} +2 -2
  18. package/dist/lib/browser/{chunk-SGTQ52SU.mjs → chunk-URST7EEN.mjs} +10 -4
  19. package/dist/lib/{node-esm/chunk-JH6F4C3I.mjs.map → browser/chunk-URST7EEN.mjs.map} +3 -3
  20. package/dist/lib/browser/{chunk-QACNNDOT.mjs → chunk-WZYRDFW7.mjs} +9 -8
  21. package/dist/lib/browser/chunk-WZYRDFW7.mjs.map +7 -0
  22. package/dist/lib/browser/{identity-created-23XJJV2N.mjs → identity-created-T6ZNVE7S.mjs} +2 -2
  23. package/dist/lib/browser/{identity-created-23XJJV2N.mjs.map → identity-created-T6ZNVE7S.mjs.map} +3 -3
  24. package/dist/lib/browser/index.mjs +14 -32
  25. package/dist/lib/browser/index.mjs.map +3 -3
  26. package/dist/lib/browser/{intent-resolver-TIXVDYN7.mjs → intent-resolver-CO262Q44.mjs} +33 -28
  27. package/dist/lib/browser/intent-resolver-CO262Q44.mjs.map +7 -0
  28. package/dist/lib/browser/meta.json +1 -1
  29. package/dist/lib/browser/{react-root-N2J7TDRX.mjs → react-root-K4IVLFYZ.mjs} +6 -6
  30. package/dist/lib/browser/{react-root-N2J7TDRX.mjs.map → react-root-K4IVLFYZ.mjs.map} +2 -2
  31. package/dist/lib/browser/{react-surface-TPNLWJJH.mjs → react-surface-TPUOK2LC.mjs} +26 -15
  32. package/dist/lib/browser/react-surface-TPUOK2LC.mjs.map +7 -0
  33. package/dist/lib/browser/{schema-defs-Z6FC4AHC.mjs → schema-defs-YDPFZELA.mjs} +2 -2
  34. package/dist/lib/browser/schema-defs-YDPFZELA.mjs.map +7 -0
  35. package/dist/lib/browser/{settings-4IMP5RYT.mjs → settings-ZYH2JWNI.mjs} +2 -2
  36. package/dist/lib/browser/{spaces-ready-TOPG6IV4.mjs → spaces-ready-3I5LISH4.mjs} +14 -12
  37. package/dist/lib/browser/spaces-ready-3I5LISH4.mjs.map +7 -0
  38. package/dist/lib/browser/{state-QYZAB45H.mjs → state-2RGW7FQG.mjs} +2 -2
  39. package/dist/lib/{node-esm/state-ZVEHQ4BJ.mjs.map → browser/state-2RGW7FQG.mjs.map} +2 -2
  40. package/dist/lib/browser/types/index.mjs +1 -1
  41. package/dist/lib/node-esm/{ObjectDetailsPanel-QKZEDSZK.mjs → ObjectDetailsPanel-7ADOXZ5W.mjs} +7 -5
  42. package/dist/lib/node-esm/ObjectDetailsPanel-7ADOXZ5W.mjs.map +7 -0
  43. package/dist/lib/node-esm/RecordMain-WLYJMYER.mjs +70 -0
  44. package/dist/lib/node-esm/RecordMain-WLYJMYER.mjs.map +7 -0
  45. package/dist/lib/node-esm/{app-graph-builder-KGIGWC72.mjs → app-graph-builder-OW2EBYRI.mjs} +57 -19
  46. package/dist/lib/node-esm/app-graph-builder-OW2EBYRI.mjs.map +7 -0
  47. package/dist/lib/node-esm/{app-graph-serializer-2ICUGQQT.mjs → app-graph-serializer-6PGC5WR5.mjs} +4 -4
  48. package/dist/lib/node-esm/{chunk-5HHYE264.mjs → chunk-FJZNSJC4.mjs} +2 -2
  49. package/dist/lib/{browser/chunk-JS3MMC42.mjs.map → node-esm/chunk-FJZNSJC4.mjs.map} +3 -3
  50. package/dist/lib/node-esm/{chunk-5T3ZH23B.mjs → chunk-HC677WUJ.mjs} +1 -1
  51. package/dist/lib/node-esm/{chunk-5T3ZH23B.mjs.map → chunk-HC677WUJ.mjs.map} +2 -2
  52. package/dist/lib/node-esm/{chunk-P442DOQ3.mjs → chunk-LGNPMOXU.mjs} +9 -8
  53. package/dist/lib/node-esm/chunk-LGNPMOXU.mjs.map +7 -0
  54. package/dist/lib/node-esm/{chunk-6X5DLJM5.mjs → chunk-NMCD2PSG.mjs} +100 -104
  55. package/dist/lib/node-esm/chunk-NMCD2PSG.mjs.map +7 -0
  56. package/dist/lib/node-esm/{chunk-SSLBYZEY.mjs → chunk-Q6AAQLQG.mjs} +3 -3
  57. package/dist/lib/node-esm/{chunk-SSLBYZEY.mjs.map → chunk-Q6AAQLQG.mjs.map} +3 -3
  58. package/dist/lib/node-esm/{chunk-JH6F4C3I.mjs → chunk-RXDT5LA5.mjs} +10 -4
  59. package/dist/lib/node-esm/chunk-RXDT5LA5.mjs.map +7 -0
  60. package/dist/lib/node-esm/{chunk-4AOMYKDE.mjs → chunk-TEUN2E4F.mjs} +68 -16
  61. package/dist/lib/node-esm/chunk-TEUN2E4F.mjs.map +7 -0
  62. package/dist/lib/node-esm/{identity-created-IJQO6GCR.mjs → identity-created-AL7NNCKH.mjs} +2 -2
  63. package/dist/lib/node-esm/{identity-created-IJQO6GCR.mjs.map → identity-created-AL7NNCKH.mjs.map} +3 -3
  64. package/dist/lib/node-esm/index.mjs +14 -32
  65. package/dist/lib/node-esm/index.mjs.map +3 -3
  66. package/dist/lib/node-esm/{intent-resolver-MHGHRGDT.mjs → intent-resolver-EXPK4B76.mjs} +33 -28
  67. package/dist/lib/node-esm/intent-resolver-EXPK4B76.mjs.map +7 -0
  68. package/dist/lib/node-esm/meta.json +1 -1
  69. package/dist/lib/node-esm/{react-root-KW3TGJGY.mjs → react-root-4OQ7MPGW.mjs} +6 -6
  70. package/dist/lib/node-esm/{react-root-KW3TGJGY.mjs.map → react-root-4OQ7MPGW.mjs.map} +2 -2
  71. package/dist/lib/node-esm/{react-surface-UUIUUD6P.mjs → react-surface-WXEXIDB7.mjs} +26 -15
  72. package/dist/lib/node-esm/react-surface-WXEXIDB7.mjs.map +7 -0
  73. package/dist/lib/node-esm/{schema-defs-WHJM7UZE.mjs → schema-defs-OYBCWKAS.mjs} +2 -2
  74. package/dist/lib/node-esm/schema-defs-OYBCWKAS.mjs.map +7 -0
  75. package/dist/lib/node-esm/{settings-SAOBPND3.mjs → settings-2RYFMMTP.mjs} +2 -2
  76. package/dist/lib/node-esm/{spaces-ready-HIUKNDZK.mjs → spaces-ready-JAP22P57.mjs} +14 -12
  77. package/dist/lib/node-esm/spaces-ready-JAP22P57.mjs.map +7 -0
  78. package/dist/lib/node-esm/{state-ZVEHQ4BJ.mjs → state-7VBVBGNS.mjs} +2 -2
  79. package/dist/lib/node-esm/state-7VBVBGNS.mjs.map +7 -0
  80. package/dist/lib/node-esm/types/index.mjs +1 -1
  81. package/dist/types/src/SpacePlugin.d.ts.map +1 -1
  82. package/dist/types/src/capabilities/app-graph-builder.d.ts +1 -1
  83. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  84. package/dist/types/src/capabilities/app-graph-serializer.d.ts +1 -1
  85. package/dist/types/src/capabilities/capabilities.d.ts +1 -1
  86. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
  87. package/dist/types/src/capabilities/identity-created.d.ts +1 -1
  88. package/dist/types/src/capabilities/identity-created.d.ts.map +1 -1
  89. package/dist/types/src/capabilities/index.d.ts +11 -12
  90. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  91. package/dist/types/src/capabilities/intent-resolver.d.ts +1 -1
  92. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  93. package/dist/types/src/capabilities/react-root.d.ts +2 -2
  94. package/dist/types/src/capabilities/react-root.d.ts.map +1 -1
  95. package/dist/types/src/capabilities/react-surface.d.ts +1 -1
  96. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  97. package/dist/types/src/capabilities/schema-defs.d.ts +1 -1
  98. package/dist/types/src/capabilities/schema-defs.d.ts.map +1 -1
  99. package/dist/types/src/capabilities/settings.d.ts +1 -1
  100. package/dist/types/src/capabilities/spaces-ready.d.ts +1 -1
  101. package/dist/types/src/capabilities/spaces-ready.d.ts.map +1 -1
  102. package/dist/types/src/capabilities/state.d.ts +1 -1
  103. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  104. package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts +2 -2
  105. package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts.map +1 -1
  106. package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts +1584 -3
  107. package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts.map +1 -1
  108. package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts +5 -3
  109. package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts.map +1 -1
  110. package/dist/types/src/components/MembersContainer.d.ts +3 -2
  111. package/dist/types/src/components/MembersContainer.d.ts.map +1 -1
  112. package/dist/types/src/components/MembersContainer.stories.d.ts +1584 -4
  113. package/dist/types/src/components/MembersContainer.stories.d.ts.map +1 -1
  114. package/dist/types/src/components/ObjectDetailsPanel.d.ts.map +1 -1
  115. package/dist/types/src/components/ObjectSettings/AdvancedObjectSettings.d.ts.map +1 -1
  116. package/dist/types/src/components/ObjectSettings/ObjectSettingsContainer.d.ts.map +1 -1
  117. package/dist/types/src/components/PopoverRenameObject.d.ts +1 -1
  118. package/dist/types/src/components/PopoverRenameObject.d.ts.map +1 -1
  119. package/dist/types/src/components/RecordMain.d.ts +7 -0
  120. package/dist/types/src/components/RecordMain.d.ts.map +1 -0
  121. package/dist/types/src/components/SpacePluginSettings.d.ts.map +1 -1
  122. package/dist/types/src/components/SpacePresence.d.ts.map +1 -1
  123. package/dist/types/src/components/SpacePresence.stories.d.ts +1411 -2
  124. package/dist/types/src/components/SpacePresence.stories.d.ts.map +1 -1
  125. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.d.ts.map +1 -1
  126. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts +1417 -3
  127. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts.map +1 -1
  128. package/dist/types/src/components/SyncStatus/SyncStatus.d.ts.map +1 -1
  129. package/dist/types/src/components/SyncStatus/SyncStatus.stories.d.ts +1418 -4
  130. package/dist/types/src/components/SyncStatus/SyncStatus.stories.d.ts.map +1 -1
  131. package/dist/types/src/components/ViewEditor.d.ts +1 -1
  132. package/dist/types/src/components/ViewEditor.d.ts.map +1 -1
  133. package/dist/types/src/components/index.d.ts +8 -2
  134. package/dist/types/src/components/index.d.ts.map +1 -1
  135. package/dist/types/src/hooks/useActiveSpace.d.ts.map +1 -1
  136. package/dist/types/src/translations.d.ts +1216 -26
  137. package/dist/types/src/translations.d.ts.map +1 -1
  138. package/dist/types/src/types/types.d.ts +25 -45
  139. package/dist/types/src/types/types.d.ts.map +1 -1
  140. package/dist/types/src/util.d.ts +6 -4
  141. package/dist/types/src/util.d.ts.map +1 -1
  142. package/dist/types/tsconfig.tsbuildinfo +1 -1
  143. package/package.json +52 -49
  144. package/src/SpacePlugin.ts +6 -24
  145. package/src/capabilities/app-graph-builder.ts +83 -32
  146. package/src/capabilities/capabilities.ts +3 -2
  147. package/src/capabilities/identity-created.ts +1 -1
  148. package/src/capabilities/index.ts +0 -1
  149. package/src/capabilities/intent-resolver.ts +25 -13
  150. package/src/capabilities/react-root.tsx +2 -1
  151. package/src/capabilities/react-surface.tsx +27 -13
  152. package/src/capabilities/schema-defs.ts +3 -2
  153. package/src/capabilities/spaces-ready.ts +10 -7
  154. package/src/capabilities/state.ts +3 -2
  155. package/src/components/AwaitingObject.tsx +1 -1
  156. package/src/components/CreateDialog/CreateObjectDialog.stories.tsx +6 -5
  157. package/src/components/CreateDialog/CreateObjectDialog.tsx +18 -8
  158. package/src/components/CreateDialog/CreateObjectPanel.tsx +18 -7
  159. package/src/components/CreateDialog/CreateSpaceDialog.tsx +1 -1
  160. package/src/components/JoinDialog.tsx +1 -1
  161. package/src/components/MembersContainer.stories.tsx +33 -8
  162. package/src/components/MembersContainer.tsx +7 -8
  163. package/src/components/ObjectDetailsPanel.tsx +4 -2
  164. package/src/components/ObjectSettings/AdvancedObjectSettings.tsx +2 -1
  165. package/src/components/ObjectSettings/ObjectSettingsContainer.tsx +3 -2
  166. package/src/components/PopoverRenameObject.tsx +6 -12
  167. package/src/components/PopoverRenameSpace.tsx +1 -1
  168. package/src/components/RecordMain.tsx +43 -0
  169. package/src/components/SchemaContainer.tsx +2 -2
  170. package/src/components/SpacePluginSettings.tsx +6 -7
  171. package/src/components/SpacePresence.stories.tsx +7 -4
  172. package/src/components/SpacePresence.tsx +7 -7
  173. package/src/components/SpaceSettings/SpaceSettingsContainer.stories.tsx +8 -5
  174. package/src/components/SpaceSettings/SpaceSettingsContainer.tsx +8 -8
  175. package/src/components/SyncStatus/SyncStatus.stories.tsx +5 -4
  176. package/src/components/SyncStatus/SyncStatus.tsx +3 -2
  177. package/src/components/ViewEditor.tsx +13 -18
  178. package/src/components/index.ts +1 -0
  179. package/src/events.ts +1 -1
  180. package/src/hooks/useActiveSpace.ts +2 -2
  181. package/src/hooks/useInputSurfaceLookup.tsx +1 -1
  182. package/src/translations.ts +8 -7
  183. package/src/types/types.ts +11 -7
  184. package/src/util.tsx +62 -13
  185. package/dist/lib/browser/ObjectDetailsPanel-YPTDQKMG.mjs.map +0 -7
  186. package/dist/lib/browser/app-graph-builder-7CZZJS3S.mjs.map +0 -7
  187. package/dist/lib/browser/chunk-QACNNDOT.mjs.map +0 -7
  188. package/dist/lib/browser/chunk-SGTQ52SU.mjs.map +0 -7
  189. package/dist/lib/browser/chunk-V7MJSSBQ.mjs.map +0 -7
  190. package/dist/lib/browser/chunk-XUYKJUU7.mjs.map +0 -7
  191. package/dist/lib/browser/intent-resolver-TIXVDYN7.mjs.map +0 -7
  192. package/dist/lib/browser/react-surface-TPNLWJJH.mjs.map +0 -7
  193. package/dist/lib/browser/schema-defs-Z6FC4AHC.mjs.map +0 -7
  194. package/dist/lib/browser/schema-tools-BNP4JTD7.mjs +0 -124
  195. package/dist/lib/browser/schema-tools-BNP4JTD7.mjs.map +0 -7
  196. package/dist/lib/browser/spaces-ready-TOPG6IV4.mjs.map +0 -7
  197. package/dist/lib/browser/state-QYZAB45H.mjs.map +0 -7
  198. package/dist/lib/node-esm/ObjectDetailsPanel-QKZEDSZK.mjs.map +0 -7
  199. package/dist/lib/node-esm/app-graph-builder-KGIGWC72.mjs.map +0 -7
  200. package/dist/lib/node-esm/chunk-4AOMYKDE.mjs.map +0 -7
  201. package/dist/lib/node-esm/chunk-6X5DLJM5.mjs.map +0 -7
  202. package/dist/lib/node-esm/chunk-P442DOQ3.mjs.map +0 -7
  203. package/dist/lib/node-esm/intent-resolver-MHGHRGDT.mjs.map +0 -7
  204. package/dist/lib/node-esm/react-surface-UUIUUD6P.mjs.map +0 -7
  205. package/dist/lib/node-esm/schema-defs-WHJM7UZE.mjs.map +0 -7
  206. package/dist/lib/node-esm/schema-tools-KWW5PTML.mjs +0 -126
  207. package/dist/lib/node-esm/schema-tools-KWW5PTML.mjs.map +0 -7
  208. package/dist/lib/node-esm/spaces-ready-HIUKNDZK.mjs.map +0 -7
  209. package/dist/types/src/capabilities/schema-tool.test.d.ts +0 -2
  210. package/dist/types/src/capabilities/schema-tool.test.d.ts.map +0 -1
  211. package/dist/types/src/capabilities/schema-tools.d.ts +0 -13
  212. package/dist/types/src/capabilities/schema-tools.d.ts.map +0 -1
  213. package/src/capabilities/schema-tool.test.ts +0 -44
  214. package/src/capabilities/schema-tools.ts +0 -125
  215. /package/dist/lib/browser/{app-graph-serializer-H6AW7KGS.mjs.map → app-graph-serializer-Q7QG4EKW.mjs.map} +0 -0
  216. /package/dist/lib/browser/{settings-4IMP5RYT.mjs.map → settings-ZYH2JWNI.mjs.map} +0 -0
  217. /package/dist/lib/node-esm/{app-graph-serializer-2ICUGQQT.mjs.map → app-graph-serializer-6PGC5WR5.mjs.map} +0 -0
  218. /package/dist/lib/node-esm/{settings-SAOBPND3.mjs.map → settings-2RYFMMTP.mjs.map} +0 -0
@@ -0,0 +1,43 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import React, { useCallback } from 'react';
6
+
7
+ import { Obj } from '@dxos/echo';
8
+ import { type JsonPath, setValue } from '@dxos/echo-schema';
9
+ import { invariant } from '@dxos/invariant';
10
+ import { getSpace } from '@dxos/react-client/echo';
11
+ import { Form, useRefQueryLookupHandler } from '@dxos/react-ui-form';
12
+
13
+ export const RecordMain = ({ record }: { record: Obj.Any }) => {
14
+ const space = getSpace(record);
15
+ const schema = Obj.getSchema(record);
16
+ invariant(schema, 'Record has no schema.');
17
+
18
+ const handleRefQueryLookup = useRefQueryLookupHandler({ space });
19
+
20
+ const handleSave = useCallback(
21
+ (values: any, { changed }: { changed: Record<JsonPath, boolean> }) => {
22
+ const id = values.id;
23
+ invariant(typeof id === 'string');
24
+
25
+ const changedPaths = Object.keys(changed).filter((path) => changed[path as JsonPath]) as JsonPath[];
26
+ for (const path of changedPaths) {
27
+ const value = values[path];
28
+ setValue(record, path, value);
29
+ }
30
+ },
31
+ [record],
32
+ );
33
+
34
+ return (
35
+ <div role='none' className='container-max-width flex flex-col p-2 gap-1 overflow-y-auto'>
36
+ <div key={record.id} className='border border-separator rounded'>
37
+ <Form autoSave schema={schema} values={record} onSave={handleSave} onQueryRefOptions={handleRefQueryLookup} />
38
+ </div>
39
+ </div>
40
+ );
41
+ };
42
+
43
+ export default RecordMain;
@@ -2,12 +2,12 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import React, { useState, useEffect } from 'react';
5
+ import React, { useEffect, useState } from 'react';
6
6
 
7
7
  import { type Type } from '@dxos/echo';
8
8
  import { type Space } from '@dxos/react-client/echo';
9
9
  import { useTranslation } from '@dxos/react-ui';
10
- import { controlItemClasses, ControlPage, ControlSection } from '@dxos/react-ui-form';
10
+ import { ControlPage, ControlSection, controlItemClasses } from '@dxos/react-ui-form';
11
11
  import { StackItem } from '@dxos/react-ui-stack';
12
12
 
13
13
  import { SPACE_PLUGIN } from '../meta';
@@ -7,8 +7,8 @@ import React from 'react';
7
7
  import { createIntent, useIntentDispatcher } from '@dxos/app-framework';
8
8
  import { useClient } from '@dxos/react-client';
9
9
  import { useSpaces } from '@dxos/react-client/echo';
10
- import { Input, toLocalizedString, useTranslation, List, ListItem, IconButton } from '@dxos/react-ui';
11
- import { controlItemClasses, ControlPage, ControlSection, DeprecatedFormInput } from '@dxos/react-ui-form';
10
+ import { IconButton, Input, List, ListItem, toLocalizedString, useTranslation } from '@dxos/react-ui';
11
+ import { ControlGroup, ControlItemInput, ControlPage, ControlSection, controlItemClasses } from '@dxos/react-ui-form';
12
12
 
13
13
  import { SPACE_PLUGIN } from '../meta';
14
14
  import { SpaceAction, type SpaceSettingsProps } from '../types';
@@ -20,18 +20,17 @@ export const SpacePluginSettings = ({ settings }: { settings: SpaceSettingsProps
20
20
  const spaces = useSpaces({ all: settings.showHidden });
21
21
  const { dispatchPromise: dispatch } = useIntentDispatcher();
22
22
 
23
- // TODO(wittjosiah): Migrate to new form container.
24
23
  return (
25
24
  <ControlPage>
26
25
  <ControlSection title={t('space settings label')} description={t('space settings description')}>
27
- <div className='pli-trimMd container-max-width'>
28
- <DeprecatedFormInput label={t('show hidden spaces label')}>
26
+ <ControlGroup>
27
+ <ControlItemInput title={t('show hidden spaces label')}>
29
28
  <Input.Switch
30
29
  checked={settings.showHidden}
31
30
  onCheckedChange={(checked) => (settings.showHidden = !!checked)}
32
31
  />
33
- </DeprecatedFormInput>
34
- </div>
32
+ </ControlItemInput>
33
+ </ControlGroup>
35
34
  <List classNames={[controlItemClasses, 'flex flex-col gap-trimSm']}>
36
35
  {spaces.map((space) => (
37
36
  <ListItem.Root key={space.id} classNames='is-full items-center'>
@@ -4,16 +4,17 @@
4
4
 
5
5
  import '@dxos-theme';
6
6
 
7
- import { type Meta } from '@storybook/react-vite';
7
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
8
8
  import React from 'react';
9
9
 
10
10
  import { IdentityDid, PublicKey } from '@dxos/keys';
11
11
  import { HaloSpaceMember, SpaceMember } from '@dxos/react-client/echo';
12
12
  import { withLayout, withTheme } from '@dxos/storybook-utils';
13
13
 
14
- import { FullPresence, type MemberPresenceProps, SmallPresence, type Member } from './SpacePresence';
15
14
  import { translations } from '../translations';
16
15
 
16
+ import { FullPresence, type Member, type MemberPresenceProps, SmallPresence } from './SpacePresence';
17
+
17
18
  const nViewers = (n: number, currentlyAttended = true): Member[] =>
18
19
  Array.from({ length: n }, () => ({
19
20
  role: HaloSpaceMember.Role.ADMIN,
@@ -98,10 +99,12 @@ export const Small = () => {
98
99
  );
99
100
  };
100
101
 
101
- const meta: Meta = {
102
+ const meta = {
102
103
  title: 'plugins/plugin-space/SpacePresence',
103
104
  decorators: [withTheme, withLayout()],
104
105
  parameters: { translations },
105
- };
106
+ } satisfies Meta<typeof IdentityDid>;
106
107
 
107
108
  export default meta;
109
+
110
+ type Story = StoryObj<typeof meta>;
@@ -9,22 +9,22 @@ import { useAppGraph, useCapability } from '@dxos/app-framework';
9
9
  import { generateName } from '@dxos/display-name';
10
10
  import { type Type } from '@dxos/echo';
11
11
  import { PublicKey, useClient } from '@dxos/react-client';
12
- import { getSpace, useMembers, type SpaceMember, fullyQualifiedId } from '@dxos/react-client/echo';
12
+ import { type SpaceMember, fullyQualifiedId, getSpace, useMembers } from '@dxos/react-client/echo';
13
13
  import { type Identity, useIdentity } from '@dxos/react-client/halo';
14
14
  import {
15
15
  Avatar,
16
16
  type AvatarContentProps,
17
+ type DxAvatar,
18
+ List,
19
+ ListItem,
20
+ Popover,
17
21
  type Size,
18
22
  type ThemedClassName,
19
23
  Tooltip,
20
- Popover,
21
- useTranslation,
22
- List,
23
- ListItem,
24
24
  useDefaultValue,
25
- type DxAvatar,
25
+ useTranslation,
26
26
  } from '@dxos/react-ui';
27
- import { AttentionGlyph, useAttended, useAttention, type AttentionGlyphProps } from '@dxos/react-ui-attention';
27
+ import { AttentionGlyph, type AttentionGlyphProps, useAttended, useAttention } from '@dxos/react-ui-attention';
28
28
  import { ComplexMap, keyToFallback } from '@dxos/util';
29
29
 
30
30
  import { SpaceCapabilities } from '../capabilities';
@@ -10,19 +10,20 @@ import React from 'react';
10
10
  import { useClientProvider, withClientProvider } from '@dxos/react-client/testing';
11
11
  import { withTheme } from '@dxos/storybook-utils';
12
12
 
13
- import { SpaceSettingsContainer, type SpaceSettingsContainerProps } from './SpaceSettingsContainer';
14
13
  import { translations } from '../../translations';
15
14
 
16
- const Story = (args: Partial<SpaceSettingsContainerProps>) => {
15
+ import { SpaceSettingsContainer, type SpaceSettingsContainerProps } from './SpaceSettingsContainer';
16
+
17
+ const Story = (props: Partial<SpaceSettingsContainerProps>) => {
17
18
  const { space } = useClientProvider();
18
19
  return (
19
20
  <div role='none' className='p-2 border border-primary-500 rounded'>
20
- <SpaceSettingsContainer {...args} space={space!} />
21
+ <SpaceSettingsContainer {...props} space={space!} />
21
22
  </div>
22
23
  );
23
24
  };
24
25
 
25
- const meta: Meta = {
26
+ const meta = {
26
27
  title: 'plugins/plugin-space/SpaceSettingsContainer',
27
28
  component: SpaceSettingsContainer,
28
29
  render: Story,
@@ -31,8 +32,10 @@ const meta: Meta = {
31
32
  translations,
32
33
  layout: 'centered',
33
34
  },
34
- };
35
+ } satisfies Meta<typeof SpaceSettingsContainer>;
35
36
 
36
37
  export default meta;
37
38
 
39
+ type Story = StoryObj<typeof meta>;
40
+
38
41
  export const Default: StoryObj<typeof SpaceSettingsContainer> = {};
@@ -2,22 +2,22 @@
2
2
  // Copyright 2024 DXOS.org
3
3
  //
4
4
 
5
- import { pipe, Schema } from 'effect';
5
+ import { Schema, pipe } from 'effect';
6
6
  import React, { type ChangeEvent, useCallback, useMemo, useState } from 'react';
7
7
 
8
- import { chain, createIntent, LayoutAction, useIntentDispatcher } from '@dxos/app-framework';
8
+ import { LayoutAction, chain, createIntent, useIntentDispatcher } from '@dxos/app-framework';
9
9
  import { log } from '@dxos/log';
10
10
  import { EdgeReplicationSetting } from '@dxos/protocols/proto/dxos/echo/metadata';
11
11
  import { useClient } from '@dxos/react-client';
12
- import { SpaceState, type Space } from '@dxos/react-client/echo';
12
+ import { type Space, SpaceState } from '@dxos/react-client/echo';
13
13
  import { Button, Input, useMulticastObservable, useTranslation } from '@dxos/react-ui';
14
14
  import {
15
- Form,
16
- type InputComponent,
17
15
  ControlItem,
18
16
  ControlItemInput,
19
- ControlSection,
20
17
  ControlPage,
18
+ ControlSection,
19
+ Form,
20
+ type InputComponent,
21
21
  } from '@dxos/react-ui-form';
22
22
  import { HuePicker, IconPicker } from '@dxos/react-ui-pickers';
23
23
  import { StackItem } from '@dxos/react-ui-stack';
@@ -162,7 +162,7 @@ export const SpaceSettingsContainer = ({ space }: SpaceSettingsContainerProps) =
162
162
  );
163
163
 
164
164
  return (
165
- <StackItem.Content classNames='block overflow-y-auto pli-2'>
165
+ <StackItem.Content classNames='block overflow-y-auto'>
166
166
  <ControlPage>
167
167
  <ControlSection
168
168
  title={t('space properties settings verbose label', { ns: SPACE_PLUGIN })}
@@ -175,7 +175,7 @@ export const SpaceSettingsContainer = ({ space }: SpaceSettingsContainerProps) =
175
175
  onSave={handleSave}
176
176
  Custom={customElements}
177
177
  outerSpacing={false}
178
- classNames='container-max-width grid grid-cols-1 md:grid-cols-[1fr_min-content] gap-4'
178
+ classNames='container-max-width grid grid-cols-1 md:grid-cols-[1fr_min-content]'
179
179
  />
180
180
  </ControlSection>
181
181
  </ControlPage>
@@ -8,10 +8,11 @@ import { type Meta, type StoryObj } from '@storybook/react-vite';
8
8
 
9
9
  import { withTheme } from '@dxos/storybook-utils';
10
10
 
11
- import { SyncStatusIndicator } from './SyncStatus';
12
11
  import { translations } from '../../translations';
13
12
 
14
- const meta: Meta = {
13
+ import { SyncStatusIndicator } from './SyncStatus';
14
+
15
+ const meta = {
15
16
  title: 'plugins/plugin-space/SyncStatusIndicator',
16
17
  component: SyncStatusIndicator,
17
18
  decorators: [withTheme],
@@ -19,11 +20,11 @@ const meta: Meta = {
19
20
  translations,
20
21
  layout: 'centered',
21
22
  },
22
- };
23
+ } satisfies Meta<typeof SyncStatusIndicator>;
23
24
 
24
25
  export default meta;
25
26
 
26
- type Story = StoryObj<typeof SyncStatusIndicator>;
27
+ type Story = StoryObj<typeof meta>;
27
28
 
28
29
  export const Default: Story = {
29
30
  args: {
@@ -6,12 +6,13 @@ import React, { useEffect, useState } from 'react';
6
6
 
7
7
  import { StatusBar } from '@dxos/plugin-status-bar';
8
8
  import { useClient } from '@dxos/react-client';
9
- import { getSyncSummary, type SpaceSyncStateMap, useSyncState } from '@dxos/react-client/echo';
9
+ import { type SpaceSyncStateMap, getSyncSummary, useSyncState } from '@dxos/react-client/echo';
10
10
  import { Icon, useTranslation } from '@dxos/react-ui';
11
11
 
12
+ import { SPACE_PLUGIN } from '../../meta';
13
+
12
14
  import { createClientSaveTracker } from './save-tracker';
13
15
  import { getIcon, getStatus } from './status';
14
- import { SPACE_PLUGIN } from '../../meta';
15
16
 
16
17
  const SYNC_STALLED_TIMEOUT = 5_000;
17
18
 
@@ -2,15 +2,15 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import React, { useCallback, useMemo } from 'react';
5
+ import React, { useCallback } from 'react';
6
6
 
7
7
  import { createIntent, useIntentDispatcher } from '@dxos/app-framework';
8
- import { Type } from '@dxos/echo';
8
+ import { Filter, Query, Type } from '@dxos/echo';
9
9
  import { invariant } from '@dxos/invariant';
10
10
  import { useClient } from '@dxos/react-client';
11
- import { Filter, getSpace, useQuery, useSchema } from '@dxos/react-client/echo';
12
- import { ViewEditor as NativeViewEditor } from '@dxos/react-ui-form';
13
- import { DataType } from '@dxos/schema';
11
+ import { getSpace, useSchema } from '@dxos/react-client/echo';
12
+ import { ViewEditor as NaturalViewEditor } from '@dxos/react-ui-form';
13
+ import { type DataType, typenameFromQuery } from '@dxos/schema';
14
14
 
15
15
  import { SpaceAction } from '../types';
16
16
 
@@ -20,24 +20,19 @@ export const ViewEditor = ({ view }: ViewEditorProps) => {
20
20
  const { dispatchPromise: dispatch } = useIntentDispatcher();
21
21
  const client = useClient();
22
22
  const space = getSpace(view);
23
- const schema = useSchema(client, space, view.query.typename);
23
+ const typename = view.query ? typenameFromQuery(view.query) : undefined;
24
+ const schema = useSchema(client, space, typename);
24
25
 
25
- const views = useQuery(space, Filter.type(DataType.View));
26
- const currentTypename = useMemo(() => view.query?.typename, [view.query?.typename]);
27
-
28
- const handleUpdateTypename = useCallback(
26
+ const handleUpdateQuery = useCallback(
29
27
  (typename: string) => {
30
28
  invariant(schema);
31
29
  invariant(Type.isMutable(schema));
32
30
 
33
- const matchingViews = views.filter((view) => view.query.typename === currentTypename);
34
- for (const view of matchingViews) {
35
- view.query.typename = typename;
36
- }
37
-
31
+ const newQuery = Query.select(Filter.typename(typename));
32
+ view.query = newQuery.ast;
38
33
  schema.updateTypename(typename);
39
34
  },
40
- [views, schema],
35
+ [view, schema],
41
36
  );
42
37
 
43
38
  const handleDelete = useCallback(
@@ -52,11 +47,11 @@ export const ViewEditor = ({ view }: ViewEditorProps) => {
52
47
  }
53
48
 
54
49
  return (
55
- <NativeViewEditor
50
+ <NaturalViewEditor
56
51
  registry={space.db.schemaRegistry}
57
52
  schema={schema}
58
53
  view={view}
59
- onTypenameChanged={Type.isMutable(schema) ? handleUpdateTypename : undefined}
54
+ onQueryChanged={Type.isMutable(schema) ? handleUpdateQuery : undefined}
60
55
  onDelete={Type.isMutable(schema) ? handleDelete : undefined}
61
56
  outerSpacing={false}
62
57
  />
@@ -23,3 +23,4 @@ export * from './ViewEditor';
23
23
 
24
24
  export const CollectionMain = lazy(() => import('./CollectionMain'));
25
25
  export const ObjectDetailsPanel = lazy(() => import('./ObjectDetailsPanel'));
26
+ export const RecordMain = lazy(() => import('./RecordMain'));
package/src/events.ts CHANGED
@@ -2,7 +2,7 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { defineEvent, Events } from '@dxos/app-framework';
5
+ import { Events, defineEvent } from '@dxos/app-framework';
6
6
 
7
7
  import { SPACE_PLUGIN } from './meta';
8
8
 
@@ -2,13 +2,13 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { Capabilities, useLayout, type PluginContext } from '@dxos/app-framework';
5
+ import { Capabilities, type PluginContext, useLayout } from '@dxos/app-framework';
6
6
  import { ClientCapabilities } from '@dxos/plugin-client';
7
7
  import { parseId, useSpace } from '@dxos/react-client/echo';
8
8
 
9
9
  export const getActiveSpace = (context: PluginContext) => {
10
- const layout = context.getCapability(Capabilities.Layout);
11
10
  const client = context.getCapability(ClientCapabilities.Client);
11
+ const layout = context.getCapability(Capabilities.Layout);
12
12
  const { spaceId } = parseId(layout.workspace);
13
13
  return spaceId ? client.spaces.get(spaceId) : undefined;
14
14
  };
@@ -5,7 +5,7 @@
5
5
  import { type Schema } from 'effect';
6
6
  import React, { useCallback } from 'react';
7
7
 
8
- import { usePluginManager, isSurfaceAvailable, Surface } from '@dxos/app-framework';
8
+ import { Surface, isSurfaceAvailable, usePluginManager } from '@dxos/app-framework';
9
9
  import { type InputProps } from '@dxos/react-ui-form';
10
10
 
11
11
  // TODO(ZaymonFC): Move this if you find yourself needing it elsewhere.
@@ -2,6 +2,7 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
+ import { Type } from '@dxos/echo';
5
6
  import { StoredSchema } from '@dxos/echo-schema';
6
7
  import { type Resource } from '@dxos/react-ui';
7
8
  import { DataType } from '@dxos/schema';
@@ -21,7 +22,7 @@ export const translations = [
21
22
  'rename object label': 'Rename collection',
22
23
  'delete object label': 'Delete collection',
23
24
  },
24
- [DataType.QueryCollection.typename]: {
25
+ [Type.getTypename(DataType.QueryCollection)]: {
25
26
  'typename label': 'Smart Collection',
26
27
  'typename label_zero': 'Smart Collections',
27
28
  'typename label_one': 'Smart Collection',
@@ -39,7 +40,7 @@ export const translations = [
39
40
  'rename object label': 'Rename record type',
40
41
  'delete object label': 'Delete record type',
41
42
  },
42
- [DataType.View.typename]: {
43
+ [Type.getTypename(DataType.View)]: {
43
44
  'typename label': 'View',
44
45
  'typename label_zero': 'Views',
45
46
  'typename label_one': 'View',
@@ -69,7 +70,7 @@ export const translations = [
69
70
  'typename label_other': 'People',
70
71
  'object name placeholder': 'New person',
71
72
  },
72
- [DataType.Project.typename]: {
73
+ [Type.getTypename(DataType.Project)]: {
73
74
  'typename label': 'Project',
74
75
  'typename label_zero': 'Projects',
75
76
  'typename label_one': 'Project',
@@ -214,10 +215,10 @@ export const translations = [
214
215
  'space settings properties label': 'General settings',
215
216
  'space properties settings verbose label': 'Manage space properties',
216
217
  'space properties settings description': 'You can configure how this space is displayed in the app here.',
217
- 'space settings schema label': 'Schema',
218
- 'schema verbose label': 'Manage schema',
219
- 'schema description': 'You can manage all of the schema stored within this space here.',
220
- 'no schemas found message': 'No schemas found',
218
+ 'space settings schema label': 'Record types',
219
+ 'schema verbose label': 'Manage record types',
220
+ 'schema description': 'You can manage all of the record types stored within this space here.',
221
+ 'no schemas found message': 'No record types found',
221
222
  'display name input placeholder': 'Space name',
222
223
  'display name description': 'Name of the space as it appears in the app.',
223
224
  'icon description': 'Icon used to represent the space in the app.',
@@ -6,7 +6,7 @@ import { Schema } from 'effect';
6
6
 
7
7
  import { type AnyIntentChain } from '@dxos/app-framework';
8
8
  import { type Obj, Type } from '@dxos/echo';
9
- import { EchoSchema, StoredSchema, type TypedObject, type BaseObject } from '@dxos/echo-schema';
9
+ import { type BaseObject, EchoSchema, StoredSchema, type TypedObject } from '@dxos/echo-schema';
10
10
  import { type PublicKey } from '@dxos/react-client';
11
11
  // TODO(wittjosiah): This pulls in full client.
12
12
  import { EchoObjectSchema, ReactiveObjectSchema, type Space, SpaceSchema } from '@dxos/react-client/echo';
@@ -238,6 +238,9 @@ export namespace SpaceAction {
238
238
  input: Schema.Struct({
239
239
  space: SpaceSchema,
240
240
  name: Schema.optional(Schema.String),
241
+ typename: Schema.optional(Schema.String),
242
+ // TODO(wittjosiah): Semantic version format.
243
+ version: Schema.optional(Schema.String),
241
244
  // TODO(wittjosiah): Schema for schema?
242
245
  schema: Schema.Any,
243
246
  }),
@@ -270,7 +273,9 @@ export namespace SpaceAction {
270
273
  export class OpenCreateObject extends Schema.TaggedClass<OpenCreateObject>()(`${SPACE_ACTION}/open-create-object`, {
271
274
  input: Schema.Struct({
272
275
  target: Schema.Union(SpaceSchema, DataType.Collection),
276
+ views: Schema.optional(Schema.Boolean),
273
277
  typename: Schema.optional(Schema.String),
278
+ initialFormValues: Schema.optional(Schema.Any),
274
279
  navigable: Schema.optional(Schema.Boolean),
275
280
  // TODO(wittjosiah): This is a function, is there a better way to handle this?
276
281
  onCreateObject: Schema.optional(Schema.Any),
@@ -362,11 +367,9 @@ export namespace CollectionAction {
362
367
 
363
368
  export const QueryCollectionForm = Schema.Struct({
364
369
  name: Schema.optional(Schema.String),
365
- typename: Schema.optional(
366
- Schema.String.annotations({
367
- [TypenameAnnotationId]: ['object-form'],
368
- }),
369
- ),
370
+ typename: Schema.String.annotations({
371
+ [TypenameAnnotationId]: ['object-form'],
372
+ }),
370
373
  });
371
374
 
372
375
  export class CreateQueryCollection extends Schema.TaggedClass<CreateQueryCollection>()(
@@ -374,7 +377,8 @@ export namespace CollectionAction {
374
377
  {
375
378
  input: QueryCollectionForm,
376
379
  output: Schema.Struct({
377
- object: DataType.QueryCollection,
380
+ // TODO(wittjosiah): Remove cast.
381
+ object: EchoObjectSchema, // DataType.QueryCollection,
378
382
  }),
379
383
  },
380
384
  ) {}