@dxos/plugin-space 0.8.4-main.a4bbb77 → 0.8.4-main.ae835ea

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 (224) hide show
  1. package/dist/lib/browser/{CollectionMain-AX7KKXWP.mjs → CollectionMain-HTKSZCRR.mjs} +2 -2
  2. package/dist/lib/browser/ObjectDetailsPanel-5B45G744.mjs +145 -0
  3. package/dist/lib/browser/ObjectDetailsPanel-5B45G744.mjs.map +7 -0
  4. package/dist/lib/browser/ObjectSettings-UFTKBP7B.mjs +146 -0
  5. package/dist/lib/browser/ObjectSettings-UFTKBP7B.mjs.map +7 -0
  6. package/dist/lib/browser/RecordMain-BCSXTSEB.mjs +99 -0
  7. package/dist/lib/browser/RecordMain-BCSXTSEB.mjs.map +7 -0
  8. package/dist/lib/browser/{app-graph-builder-W7RVDAUA.mjs → app-graph-builder-QJFO4ANM.mjs} +37 -34
  9. package/dist/lib/browser/app-graph-builder-QJFO4ANM.mjs.map +7 -0
  10. package/dist/lib/browser/{app-graph-serializer-VLHVTDX4.mjs → app-graph-serializer-3R5NVV7U.mjs} +5 -5
  11. package/dist/lib/browser/{chunk-E2I747A7.mjs → chunk-2NS3VPSY.mjs} +2 -2
  12. package/dist/lib/browser/chunk-2NS3VPSY.mjs.map +7 -0
  13. package/dist/lib/browser/{chunk-ZIZ2JLW6.mjs → chunk-4V4JNJ33.mjs} +12 -4
  14. package/dist/lib/browser/chunk-4V4JNJ33.mjs.map +7 -0
  15. package/dist/lib/browser/{chunk-2BFVC5K6.mjs → chunk-ENBBJSNE.mjs} +230 -254
  16. package/dist/lib/browser/chunk-ENBBJSNE.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-HS2VD6DN.mjs +166 -0
  18. package/dist/lib/browser/chunk-HS2VD6DN.mjs.map +7 -0
  19. package/dist/lib/browser/{chunk-PN27K4I7.mjs → chunk-OWNBEI5J.mjs} +23 -14
  20. package/dist/lib/browser/chunk-OWNBEI5J.mjs.map +7 -0
  21. package/dist/lib/browser/{chunk-JCHSUOPF.mjs → chunk-SLDQWMQ2.mjs} +12 -7
  22. package/dist/lib/browser/chunk-SLDQWMQ2.mjs.map +7 -0
  23. package/dist/lib/browser/chunk-VZBIIYFM.mjs +16 -0
  24. package/dist/lib/browser/chunk-VZBIIYFM.mjs.map +7 -0
  25. package/dist/lib/browser/{chunk-EIXZABXD.mjs → chunk-WJXU4GKV.mjs} +2 -2
  26. package/dist/lib/browser/index.mjs +31 -31
  27. package/dist/lib/browser/index.mjs.map +3 -3
  28. package/dist/lib/browser/{intent-resolver-HA7DPAUE.mjs → intent-resolver-MBVOLXFQ.mjs} +30 -23
  29. package/dist/lib/browser/intent-resolver-MBVOLXFQ.mjs.map +7 -0
  30. package/dist/lib/browser/meta.json +1 -1
  31. package/dist/lib/browser/{react-root-YQUJU64P.mjs → react-root-NKEKCEYM.mjs} +7 -7
  32. package/dist/lib/browser/{react-surface-HTXYMRSW.mjs → react-surface-PYSN2MBY.mjs} +15 -46
  33. package/dist/lib/browser/react-surface-PYSN2MBY.mjs.map +7 -0
  34. package/dist/lib/browser/{schema-defs-R56ZDBZ7.mjs → schema-defs-DWYK7TYW.mjs} +3 -3
  35. package/dist/lib/browser/{settings-5XPQMSPO.mjs → settings-ZUCC3ZLB.mjs} +3 -3
  36. package/dist/lib/browser/{spaces-ready-YY77ANIF.mjs → spaces-ready-HTWWJHLR.mjs} +6 -6
  37. package/dist/lib/browser/spaces-ready-HTWWJHLR.mjs.map +7 -0
  38. package/dist/lib/browser/{state-Y4RVCG4A.mjs → state-ISVAKMO7.mjs} +3 -3
  39. package/dist/lib/browser/types/index.mjs +2 -2
  40. package/dist/lib/node-esm/{CollectionMain-EU57SRYK.mjs → CollectionMain-OUHGG6OC.mjs} +2 -2
  41. package/dist/lib/node-esm/ObjectDetailsPanel-4SDHQVQU.mjs +146 -0
  42. package/dist/lib/node-esm/ObjectDetailsPanel-4SDHQVQU.mjs.map +7 -0
  43. package/dist/lib/node-esm/ObjectSettings-EU6F43RP.mjs +147 -0
  44. package/dist/lib/node-esm/ObjectSettings-EU6F43RP.mjs.map +7 -0
  45. package/dist/lib/node-esm/RecordMain-SD76DGOR.mjs +100 -0
  46. package/dist/lib/node-esm/RecordMain-SD76DGOR.mjs.map +7 -0
  47. package/dist/lib/node-esm/{app-graph-builder-5ZJJUMQI.mjs → app-graph-builder-B23W62HY.mjs} +37 -34
  48. package/dist/lib/node-esm/app-graph-builder-B23W62HY.mjs.map +7 -0
  49. package/dist/lib/node-esm/{app-graph-serializer-EZJSGJUT.mjs → app-graph-serializer-3Z3EXEEF.mjs} +5 -5
  50. package/dist/lib/node-esm/chunk-BDEFTL6K.mjs +18 -0
  51. package/dist/lib/node-esm/chunk-BDEFTL6K.mjs.map +7 -0
  52. package/dist/lib/node-esm/{chunk-5XRYHWL7.mjs → chunk-G4PDWB7G.mjs} +12 -4
  53. package/dist/lib/node-esm/chunk-G4PDWB7G.mjs.map +7 -0
  54. package/dist/lib/node-esm/{chunk-SVFKU7EW.mjs → chunk-H4JILUJK.mjs} +2 -2
  55. package/dist/lib/node-esm/{chunk-BLPXWPLB.mjs → chunk-KKPCCA5O.mjs} +230 -254
  56. package/dist/lib/node-esm/chunk-KKPCCA5O.mjs.map +7 -0
  57. package/dist/lib/node-esm/chunk-PM4ZIGKC.mjs +167 -0
  58. package/dist/lib/node-esm/chunk-PM4ZIGKC.mjs.map +7 -0
  59. package/dist/lib/node-esm/{chunk-XDQXUZMK.mjs → chunk-XEVIWD3O.mjs} +23 -14
  60. package/dist/lib/node-esm/chunk-XEVIWD3O.mjs.map +7 -0
  61. package/dist/lib/node-esm/{chunk-6WNZW6KT.mjs → chunk-YFQXFQGT.mjs} +12 -7
  62. package/dist/lib/node-esm/chunk-YFQXFQGT.mjs.map +7 -0
  63. package/dist/lib/node-esm/{chunk-IJVBBVCL.mjs → chunk-ZLMFLI7G.mjs} +2 -2
  64. package/dist/lib/node-esm/chunk-ZLMFLI7G.mjs.map +7 -0
  65. package/dist/lib/node-esm/index.mjs +31 -31
  66. package/dist/lib/node-esm/index.mjs.map +3 -3
  67. package/dist/lib/node-esm/{intent-resolver-LQNHMPIX.mjs → intent-resolver-IWI47NTW.mjs} +30 -23
  68. package/dist/lib/node-esm/intent-resolver-IWI47NTW.mjs.map +7 -0
  69. package/dist/lib/node-esm/meta.json +1 -1
  70. package/dist/lib/node-esm/{react-root-UTLJEIKE.mjs → react-root-LX7SIG6M.mjs} +7 -7
  71. package/dist/lib/node-esm/{react-surface-LYDYON3U.mjs → react-surface-6SVGOZNJ.mjs} +15 -46
  72. package/dist/lib/node-esm/react-surface-6SVGOZNJ.mjs.map +7 -0
  73. package/dist/lib/node-esm/{schema-defs-7IMJPIWS.mjs → schema-defs-EOG2UPJU.mjs} +3 -3
  74. package/dist/lib/node-esm/{settings-XBSK5KHH.mjs → settings-ZDJNLFGW.mjs} +3 -3
  75. package/dist/lib/node-esm/{spaces-ready-YX4IHT4P.mjs → spaces-ready-VUGYPF4L.mjs} +6 -6
  76. package/dist/lib/node-esm/spaces-ready-VUGYPF4L.mjs.map +7 -0
  77. package/dist/lib/node-esm/{state-HOHAVPUO.mjs → state-QZ4Q6ZRL.mjs} +3 -3
  78. package/dist/lib/node-esm/types/index.mjs +2 -2
  79. package/dist/types/src/SpacePlugin.d.ts.map +1 -1
  80. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  81. package/dist/types/src/capabilities/capabilities.d.ts +2 -1
  82. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
  83. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  84. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  85. package/dist/types/src/components/CreateDialog/CreateObjectDialog.d.ts.map +1 -1
  86. package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts +80 -0
  87. package/dist/types/src/components/CreateDialog/CreateObjectDialog.stories.d.ts.map +1 -1
  88. package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts +1 -1
  89. package/dist/types/src/components/CreateDialog/CreateObjectPanel.d.ts.map +1 -1
  90. package/dist/types/src/components/CreateDialog/CreateSpaceDialog.d.ts.map +1 -1
  91. package/dist/types/src/components/MembersContainer.stories.d.ts +80 -0
  92. package/dist/types/src/components/MembersContainer.stories.d.ts.map +1 -1
  93. package/dist/types/src/components/ObjectDetailsPanel/ObjectDetailsPanel.d.ts +9 -0
  94. package/dist/types/src/components/ObjectDetailsPanel/ObjectDetailsPanel.d.ts.map +1 -0
  95. package/dist/types/src/components/ObjectDetailsPanel/ObjectForm.d.ts +10 -0
  96. package/dist/types/src/components/ObjectDetailsPanel/ObjectForm.d.ts.map +1 -0
  97. package/dist/types/src/components/ObjectDetailsPanel/index.d.ts +3 -0
  98. package/dist/types/src/components/ObjectDetailsPanel/index.d.ts.map +1 -0
  99. package/dist/types/src/components/ObjectSettings/BaseObjectSettings.d.ts +2 -2
  100. package/dist/types/src/components/ObjectSettings/BaseObjectSettings.d.ts.map +1 -1
  101. package/dist/types/src/components/ObjectSettings/BaseObjectSettings.stories.d.ts +1500 -0
  102. package/dist/types/src/components/ObjectSettings/BaseObjectSettings.stories.d.ts.map +1 -0
  103. package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts +1 -1
  104. package/dist/types/src/components/ObjectSettings/ForeignKeys.d.ts.map +1 -1
  105. package/dist/types/src/components/ObjectSettings/index.d.ts +2 -1
  106. package/dist/types/src/components/ObjectSettings/index.d.ts.map +1 -1
  107. package/dist/types/src/components/RecordMain.d.ts +4 -3
  108. package/dist/types/src/components/RecordMain.d.ts.map +1 -1
  109. package/dist/types/src/components/RecordMain.stories.d.ts +1667 -0
  110. package/dist/types/src/components/RecordMain.stories.d.ts.map +1 -0
  111. package/dist/types/src/components/SpacePresence.stories.d.ts +80 -0
  112. package/dist/types/src/components/SpacePresence.stories.d.ts.map +1 -1
  113. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.d.ts.map +1 -1
  114. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts +80 -0
  115. package/dist/types/src/components/SpaceSettings/SpaceSettingsContainer.stories.d.ts.map +1 -1
  116. package/dist/types/src/components/SyncStatus/SyncStatus.d.ts.map +1 -1
  117. package/dist/types/src/components/SyncStatus/SyncStatus.stories.d.ts +81 -1
  118. package/dist/types/src/components/SyncStatus/SyncStatus.stories.d.ts.map +1 -1
  119. package/dist/types/src/components/ViewEditor.d.ts.map +1 -1
  120. package/dist/types/src/components/index.d.ts +4 -6
  121. package/dist/types/src/components/index.d.ts.map +1 -1
  122. package/dist/types/src/hooks/index.d.ts +1 -0
  123. package/dist/types/src/hooks/index.d.ts.map +1 -1
  124. package/dist/types/src/hooks/useInputSurfaceLookup.d.ts +1 -1
  125. package/dist/types/src/hooks/useInputSurfaceLookup.d.ts.map +1 -1
  126. package/dist/types/src/hooks/usePath.d.ts +1 -1
  127. package/dist/types/src/hooks/usePath.d.ts.map +1 -1
  128. package/dist/types/src/hooks/useTypeOptions.d.ts +10 -0
  129. package/dist/types/src/hooks/useTypeOptions.d.ts.map +1 -0
  130. package/dist/types/src/meta.d.ts.map +1 -1
  131. package/dist/types/src/translations.d.ts +80 -0
  132. package/dist/types/src/translations.d.ts.map +1 -1
  133. package/dist/types/src/types/types.d.ts +6 -4
  134. package/dist/types/src/types/types.d.ts.map +1 -1
  135. package/dist/types/src/util.d.ts +4 -1
  136. package/dist/types/src/util.d.ts.map +1 -1
  137. package/dist/types/tsconfig.tsbuildinfo +1 -1
  138. package/package.json +50 -48
  139. package/src/SpacePlugin.ts +7 -13
  140. package/src/capabilities/app-graph-builder.ts +29 -24
  141. package/src/capabilities/capabilities.ts +7 -2
  142. package/src/capabilities/intent-resolver.ts +13 -8
  143. package/src/capabilities/react-surface.tsx +6 -77
  144. package/src/capabilities/spaces-ready.ts +1 -1
  145. package/src/components/CreateDialog/CreateObjectDialog.tsx +5 -4
  146. package/src/components/CreateDialog/CreateObjectPanel.tsx +2 -2
  147. package/src/components/CreateDialog/CreateSpaceDialog.tsx +2 -1
  148. package/src/components/MembersContainer.tsx +1 -1
  149. package/src/components/{ObjectDetailsPanel.tsx → ObjectDetailsPanel/ObjectDetailsPanel.tsx} +8 -35
  150. package/src/components/ObjectDetailsPanel/ObjectForm.tsx +75 -0
  151. package/src/components/ObjectDetailsPanel/index.ts +7 -0
  152. package/src/components/ObjectSettings/AdvancedObjectSettings.tsx +1 -1
  153. package/src/components/ObjectSettings/BaseObjectSettings.stories.tsx +63 -0
  154. package/src/components/ObjectSettings/BaseObjectSettings.tsx +86 -26
  155. package/src/components/ObjectSettings/ForeignKeys.tsx +1 -1
  156. package/src/components/ObjectSettings/index.ts +3 -1
  157. package/src/components/RecordMain.stories.tsx +116 -0
  158. package/src/components/RecordMain.tsx +69 -29
  159. package/src/components/SchemaContainer.tsx +1 -1
  160. package/src/components/SpacePresence.tsx +1 -1
  161. package/src/components/SpaceSettings/SpaceSettingsContainer.tsx +4 -3
  162. package/src/components/SyncStatus/InlineSyncStatus.tsx +5 -5
  163. package/src/components/SyncStatus/SyncStatus.stories.tsx +3 -2
  164. package/src/components/SyncStatus/SyncStatus.tsx +93 -3
  165. package/src/components/ViewEditor.tsx +6 -7
  166. package/src/components/index.ts +1 -1
  167. package/src/hooks/index.ts +1 -0
  168. package/src/hooks/useInputSurfaceLookup.tsx +1 -1
  169. package/src/hooks/usePath.ts +1 -1
  170. package/src/hooks/useTypeOptions.ts +59 -0
  171. package/src/meta.ts +5 -0
  172. package/src/translations.ts +10 -1
  173. package/src/types/types.ts +9 -5
  174. package/src/util.tsx +22 -8
  175. package/dist/lib/browser/ObjectDetailsPanel-ETI5YBTH.mjs +0 -90
  176. package/dist/lib/browser/ObjectDetailsPanel-ETI5YBTH.mjs.map +0 -7
  177. package/dist/lib/browser/RecordMain-TEBGAVSL.mjs +0 -68
  178. package/dist/lib/browser/RecordMain-TEBGAVSL.mjs.map +0 -7
  179. package/dist/lib/browser/app-graph-builder-W7RVDAUA.mjs.map +0 -7
  180. package/dist/lib/browser/chunk-2BFVC5K6.mjs.map +0 -7
  181. package/dist/lib/browser/chunk-E2I747A7.mjs.map +0 -7
  182. package/dist/lib/browser/chunk-ELJDGQTO.mjs +0 -94
  183. package/dist/lib/browser/chunk-ELJDGQTO.mjs.map +0 -7
  184. package/dist/lib/browser/chunk-IRKDREHY.mjs +0 -11
  185. package/dist/lib/browser/chunk-IRKDREHY.mjs.map +0 -7
  186. package/dist/lib/browser/chunk-JCHSUOPF.mjs.map +0 -7
  187. package/dist/lib/browser/chunk-PN27K4I7.mjs.map +0 -7
  188. package/dist/lib/browser/chunk-ZIZ2JLW6.mjs.map +0 -7
  189. package/dist/lib/browser/intent-resolver-HA7DPAUE.mjs.map +0 -7
  190. package/dist/lib/browser/react-surface-HTXYMRSW.mjs.map +0 -7
  191. package/dist/lib/browser/spaces-ready-YY77ANIF.mjs.map +0 -7
  192. package/dist/lib/node-esm/ObjectDetailsPanel-TQ5GN4QJ.mjs +0 -91
  193. package/dist/lib/node-esm/ObjectDetailsPanel-TQ5GN4QJ.mjs.map +0 -7
  194. package/dist/lib/node-esm/RecordMain-WLYJMYER.mjs +0 -70
  195. package/dist/lib/node-esm/RecordMain-WLYJMYER.mjs.map +0 -7
  196. package/dist/lib/node-esm/app-graph-builder-5ZJJUMQI.mjs.map +0 -7
  197. package/dist/lib/node-esm/chunk-5XRYHWL7.mjs.map +0 -7
  198. package/dist/lib/node-esm/chunk-6WNZW6KT.mjs.map +0 -7
  199. package/dist/lib/node-esm/chunk-BLPXWPLB.mjs.map +0 -7
  200. package/dist/lib/node-esm/chunk-IJVBBVCL.mjs.map +0 -7
  201. package/dist/lib/node-esm/chunk-MWNATOXL.mjs +0 -13
  202. package/dist/lib/node-esm/chunk-MWNATOXL.mjs.map +0 -7
  203. package/dist/lib/node-esm/chunk-Q6AAQLQG.mjs +0 -96
  204. package/dist/lib/node-esm/chunk-Q6AAQLQG.mjs.map +0 -7
  205. package/dist/lib/node-esm/chunk-XDQXUZMK.mjs.map +0 -7
  206. package/dist/lib/node-esm/intent-resolver-LQNHMPIX.mjs.map +0 -7
  207. package/dist/lib/node-esm/react-surface-LYDYON3U.mjs.map +0 -7
  208. package/dist/lib/node-esm/spaces-ready-YX4IHT4P.mjs.map +0 -7
  209. package/dist/types/src/components/ObjectDetailsPanel.d.ts +0 -9
  210. package/dist/types/src/components/ObjectDetailsPanel.d.ts.map +0 -1
  211. /package/dist/lib/browser/{CollectionMain-AX7KKXWP.mjs.map → CollectionMain-HTKSZCRR.mjs.map} +0 -0
  212. /package/dist/lib/browser/{app-graph-serializer-VLHVTDX4.mjs.map → app-graph-serializer-3R5NVV7U.mjs.map} +0 -0
  213. /package/dist/lib/browser/{chunk-EIXZABXD.mjs.map → chunk-WJXU4GKV.mjs.map} +0 -0
  214. /package/dist/lib/browser/{react-root-YQUJU64P.mjs.map → react-root-NKEKCEYM.mjs.map} +0 -0
  215. /package/dist/lib/browser/{schema-defs-R56ZDBZ7.mjs.map → schema-defs-DWYK7TYW.mjs.map} +0 -0
  216. /package/dist/lib/browser/{settings-5XPQMSPO.mjs.map → settings-ZUCC3ZLB.mjs.map} +0 -0
  217. /package/dist/lib/browser/{state-Y4RVCG4A.mjs.map → state-ISVAKMO7.mjs.map} +0 -0
  218. /package/dist/lib/node-esm/{CollectionMain-EU57SRYK.mjs.map → CollectionMain-OUHGG6OC.mjs.map} +0 -0
  219. /package/dist/lib/node-esm/{app-graph-serializer-EZJSGJUT.mjs.map → app-graph-serializer-3Z3EXEEF.mjs.map} +0 -0
  220. /package/dist/lib/node-esm/{chunk-SVFKU7EW.mjs.map → chunk-H4JILUJK.mjs.map} +0 -0
  221. /package/dist/lib/node-esm/{react-root-UTLJEIKE.mjs.map → react-root-LX7SIG6M.mjs.map} +0 -0
  222. /package/dist/lib/node-esm/{schema-defs-7IMJPIWS.mjs.map → schema-defs-EOG2UPJU.mjs.map} +0 -0
  223. /package/dist/lib/node-esm/{settings-XBSK5KHH.mjs.map → settings-ZDJNLFGW.mjs.map} +0 -0
  224. /package/dist/lib/node-esm/{state-HOHAVPUO.mjs.map → state-QZ4Q6ZRL.mjs.map} +0 -0
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  meta
3
- } from "./chunk-IRKDREHY.mjs";
3
+ } from "./chunk-VZBIIYFM.mjs";
4
4
 
5
5
  // src/components/CollectionMain.tsx
6
6
  import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
@@ -28,4 +28,4 @@ export {
28
28
  CollectionMain,
29
29
  CollectionMain_default as default
30
30
  };
31
- //# sourceMappingURL=CollectionMain-AX7KKXWP.mjs.map
31
+ //# sourceMappingURL=CollectionMain-HTKSZCRR.mjs.map
@@ -0,0 +1,145 @@
1
+ import {
2
+ meta
3
+ } from "./chunk-VZBIIYFM.mjs";
4
+
5
+ // src/components/ObjectDetailsPanel/ObjectDetailsPanel.tsx
6
+ import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
7
+ import React2 from "react";
8
+ import { useClient } from "@dxos/react-client";
9
+ import { Filter, getSpace as getSpace2, useQuery, useSchema } from "@dxos/react-client/echo";
10
+ import { Callout, useTranslation } from "@dxos/react-ui";
11
+ import { useSelected } from "@dxos/react-ui-attention";
12
+ import { getTypenameFromQuery } from "@dxos/schema";
13
+ import { isNonNullable } from "@dxos/util";
14
+
15
+ // src/components/ObjectDetailsPanel/ObjectForm.tsx
16
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
17
+ import * as Schema from "effect/Schema";
18
+ import React, { useCallback, useMemo } from "react";
19
+ import { DXN, Obj, Tag, Type } from "@dxos/echo";
20
+ import { setValue } from "@dxos/echo/internal";
21
+ import { invariant } from "@dxos/invariant";
22
+ import { getSpace } from "@dxos/react-client/echo";
23
+ import { Form, useRefQueryLookupHandler } from "@dxos/react-ui-form";
24
+ var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-space/src/components/ObjectDetailsPanel/ObjectForm.tsx";
25
+ var TagSchema = Tag.Tag.pipe(Schema.omit("id"));
26
+ var ObjectForm = ({ object, schema }) => {
27
+ var _effect = _useSignals();
28
+ try {
29
+ const space = getSpace(object);
30
+ const handleRefQueryLookup = useRefQueryLookupHandler({
31
+ space
32
+ });
33
+ const formSchema = useMemo(() => Schema.Struct({
34
+ tag: Type.Ref(Tag.Tag).pipe(Schema.optional)
35
+ }).pipe(Schema.extend(schema)), [
36
+ schema
37
+ ]);
38
+ const meta2 = Obj.getMeta(object);
39
+ const tag = meta2.tags?.[0] ? space?.db.ref(DXN.parse(meta2.tags?.[0])) : void 0;
40
+ const values = useMemo(() => ({
41
+ tag,
42
+ ...object
43
+ }), [
44
+ object,
45
+ tag
46
+ ]);
47
+ const handleCreateTag = useCallback((values2) => {
48
+ invariant(space, void 0, {
49
+ F: __dxlog_file,
50
+ L: 34,
51
+ S: void 0,
52
+ A: [
53
+ "space",
54
+ ""
55
+ ]
56
+ });
57
+ const tag2 = space.db.add(Tag.make(values2));
58
+ const meta3 = Obj.getMeta(object);
59
+ meta3.tags = [
60
+ Obj.getDXN(tag2).toString()
61
+ ];
62
+ }, []);
63
+ const handleSave = useCallback((values2, { changed }) => {
64
+ const changedPaths = Object.keys(changed).filter((path) => changed[path]);
65
+ for (const path of changedPaths) {
66
+ if (path === "tag") {
67
+ const tag2 = values2[path];
68
+ const meta3 = Obj.getMeta(object);
69
+ const currentTag = meta3.tags?.[0];
70
+ if (currentTag !== tag2?.dxn.toString()) {
71
+ meta3.tags = tag2 ? [
72
+ tag2.dxn.toString()
73
+ ] : [];
74
+ }
75
+ continue;
76
+ }
77
+ const value = values2[path];
78
+ setValue(object, path, value);
79
+ }
80
+ }, [
81
+ object
82
+ ]);
83
+ return /* @__PURE__ */ React.createElement(Form, {
84
+ autoSave: true,
85
+ schema: formSchema,
86
+ values,
87
+ createSchema: TagSchema,
88
+ createOptionIcon: "ph--plus--regular",
89
+ createOptionLabel: [
90
+ "add tag label",
91
+ {
92
+ ns: meta.id
93
+ }
94
+ ],
95
+ createInitialValuePath: "label",
96
+ onCreate: handleCreateTag,
97
+ onSave: handleSave,
98
+ onQueryRefOptions: handleRefQueryLookup
99
+ });
100
+ } finally {
101
+ _effect.f();
102
+ }
103
+ };
104
+
105
+ // src/components/ObjectDetailsPanel/ObjectDetailsPanel.tsx
106
+ var ObjectDetailsPanel = ({ objectId, view }) => {
107
+ var _effect = _useSignals2();
108
+ try {
109
+ const { t } = useTranslation(meta.id);
110
+ const client = useClient();
111
+ const space = getSpace2(view);
112
+ const typename = view.query ? getTypenameFromQuery(view.query.ast) : void 0;
113
+ const schema = useSchema(client, space, typename);
114
+ const queriedObjects = useQuery(space, schema ? Filter.type(schema) : Filter.nothing());
115
+ const selectedRows = useSelected(objectId, "multi");
116
+ const selectedObjects = selectedRows.map((id) => queriedObjects.find((obj) => obj.id === id)).filter(isNonNullable);
117
+ if (selectedObjects.length === 0) {
118
+ return /* @__PURE__ */ React2.createElement("div", {
119
+ role: "none",
120
+ className: "plb-cardSpacingBlock pli-cardSpacingInline"
121
+ }, /* @__PURE__ */ React2.createElement(Callout.Root, {
122
+ classNames: "is-full"
123
+ }, /* @__PURE__ */ React2.createElement(Callout.Title, null, t("row details no selection label"))));
124
+ }
125
+ return /* @__PURE__ */ React2.createElement("div", {
126
+ role: "none",
127
+ className: "bs-full is-full flex flex-col p-2 gap-1 overflow-y-auto"
128
+ }, schema && selectedObjects.map((object) => /* @__PURE__ */ React2.createElement("div", {
129
+ key: object.id,
130
+ className: "border border-separator rounded"
131
+ }, /* @__PURE__ */ React2.createElement(ObjectForm, {
132
+ object,
133
+ schema
134
+ }))));
135
+ } finally {
136
+ _effect.f();
137
+ }
138
+ };
139
+
140
+ // src/components/ObjectDetailsPanel/index.ts
141
+ var ObjectDetailsPanel_default = ObjectDetailsPanel;
142
+ export {
143
+ ObjectDetailsPanel_default as default
144
+ };
145
+ //# sourceMappingURL=ObjectDetailsPanel-5B45G744.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/ObjectDetailsPanel/ObjectDetailsPanel.tsx", "../../../src/components/ObjectDetailsPanel/ObjectForm.tsx", "../../../src/components/ObjectDetailsPanel/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { useClient } from '@dxos/react-client';\nimport { Filter, getSpace, useQuery, useSchema } from '@dxos/react-client/echo';\nimport { Callout, useTranslation } from '@dxos/react-ui';\nimport { useSelected } from '@dxos/react-ui-attention';\nimport { type DataType } from '@dxos/schema';\nimport { getTypenameFromQuery } from '@dxos/schema';\nimport { isNonNullable } from '@dxos/util';\n\nimport { meta } from '../../meta';\n\nimport { ObjectForm } from './ObjectForm';\n\ntype RowDetailsPanelProps = { objectId: string; view: DataType.View };\n\nexport const ObjectDetailsPanel = ({ objectId, view }: RowDetailsPanelProps) => {\n const { t } = useTranslation(meta.id);\n const client = useClient();\n const space = getSpace(view);\n const typename = view.query ? getTypenameFromQuery(view.query.ast) : undefined;\n const schema = useSchema(client, space, typename);\n\n const queriedObjects = useQuery(space, schema ? Filter.type(schema) : Filter.nothing());\n const selectedRows = useSelected(objectId, 'multi');\n const selectedObjects = selectedRows.map((id) => queriedObjects.find((obj) => obj.id === id)).filter(isNonNullable);\n\n if (selectedObjects.length === 0) {\n return (\n <div role='none' className='plb-cardSpacingBlock pli-cardSpacingInline'>\n <Callout.Root classNames='is-full'>\n <Callout.Title>{t('row details no selection label')}</Callout.Title>\n </Callout.Root>\n </div>\n );\n }\n\n return (\n <div role='none' className='bs-full is-full flex flex-col p-2 gap-1 overflow-y-auto'>\n {schema &&\n selectedObjects.map((object) => (\n <div key={object.id} className='border border-separator rounded'>\n <ObjectForm object={object} schema={schema} />\n </div>\n ))}\n </div>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\nimport React, { useCallback, useMemo } from 'react';\n\nimport { DXN, Obj, Tag, Type } from '@dxos/echo';\nimport { type JsonPath, setValue } from '@dxos/echo/internal';\nimport { invariant } from '@dxos/invariant';\nimport { getSpace } from '@dxos/react-client/echo';\nimport { Form, useRefQueryLookupHandler } from '@dxos/react-ui-form';\n\nimport { meta as pluginMeta } from '../../meta';\n\nconst TagSchema = Tag.Tag.pipe(Schema.omit('id'));\n\ntype ObjectFormProps = { object: Obj.Any; schema: Schema.Schema.AnyNoContext };\n\nexport const ObjectForm = ({ object, schema }: ObjectFormProps) => {\n const space = getSpace(object);\n const handleRefQueryLookup = useRefQueryLookupHandler({ space });\n\n const formSchema = useMemo(\n () => Schema.Struct({ tag: Type.Ref(Tag.Tag).pipe(Schema.optional) }).pipe(Schema.extend(schema)),\n [schema],\n );\n\n const meta = Obj.getMeta(object);\n const tag = meta.tags?.[0] ? space?.db.ref(DXN.parse(meta.tags?.[0])) : undefined;\n const values = useMemo(() => ({ tag, ...object }), [object, tag]);\n\n const handleCreateTag = useCallback((values: Schema.Schema.Type<typeof TagSchema>) => {\n invariant(space);\n const tag = space.db.add(Tag.make(values));\n const meta = Obj.getMeta(object);\n meta.tags = [Obj.getDXN(tag).toString()];\n }, []);\n\n const handleSave = useCallback(\n (values: any, { changed }: { changed: Record<JsonPath, boolean> }) => {\n const changedPaths = Object.keys(changed).filter((path) => changed[path as JsonPath]) as JsonPath[];\n for (const path of changedPaths) {\n if (path === 'tag') {\n const tag = values[path];\n const meta = Obj.getMeta(object);\n const currentTag = meta.tags?.[0];\n if (currentTag !== tag?.dxn.toString()) {\n meta.tags = tag ? [tag.dxn.toString()] : [];\n }\n continue;\n }\n\n const value = values[path];\n setValue(object, path, value);\n }\n },\n [object],\n );\n\n return (\n <Form\n autoSave\n schema={formSchema}\n values={values}\n createSchema={TagSchema}\n createOptionIcon='ph--plus--regular'\n createOptionLabel={['add tag label', { ns: pluginMeta.id }]}\n createInitialValuePath='label'\n onCreate={handleCreateTag}\n onSave={handleSave}\n onQueryRefOptions={handleRefQueryLookup}\n />\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { ObjectDetailsPanel } from './ObjectDetailsPanel';\n\nexport default ObjectDetailsPanel;\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "useClient", "Filter", "getSpace", "useQuery", "useSchema", "Callout", "useTranslation", "useSelected", "getTypenameFromQuery", "isNonNullable", "Schema", "React", "useCallback", "useMemo", "DXN", "Obj", "Tag", "Type", "setValue", "invariant", "getSpace", "Form", "useRefQueryLookupHandler", "TagSchema", "Tag", "pipe", "omit", "ObjectForm", "object", "schema", "space", "getSpace", "handleRefQueryLookup", "useRefQueryLookupHandler", "formSchema", "useMemo", "Struct", "tag", "Type", "Ref", "optional", "extend", "meta", "Obj", "getMeta", "tags", "db", "ref", "DXN", "parse", "undefined", "values", "handleCreateTag", "useCallback", "invariant", "add", "make", "getDXN", "toString", "handleSave", "changed", "changedPaths", "Object", "keys", "filter", "path", "currentTag", "dxn", "value", "setValue", "Form", "autoSave", "createSchema", "createOptionIcon", "createOptionLabel", "ns", "pluginMeta", "id", "createInitialValuePath", "onCreate", "onSave", "onQueryRefOptions", "ObjectDetailsPanel", "objectId", "view", "t", "useTranslation", "meta", "id", "client", "useClient", "space", "getSpace", "typename", "query", "getTypenameFromQuery", "ast", "undefined", "schema", "useSchema", "queriedObjects", "useQuery", "Filter", "type", "nothing", "selectedRows", "useSelected", "selectedObjects", "map", "find", "obj", "filter", "isNonNullable", "length", "React", "div", "role", "className", "Callout", "Root", "classNames", "Title", "object", "key", "ObjectForm", "ObjectDetailsPanel"]
7
+ }
@@ -0,0 +1,146 @@
1
+ import {
2
+ meta
3
+ } from "./chunk-VZBIIYFM.mjs";
4
+
5
+ // src/components/ObjectSettings/ObjectSettingsContainer.tsx
6
+ import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
7
+ import React2, { useMemo as useMemo2 } from "react";
8
+ import { Surface } from "@dxos/app-framework";
9
+ import { Clipboard, Toolbar } from "@dxos/react-ui";
10
+ import { StackItem } from "@dxos/react-ui-stack";
11
+
12
+ // src/components/ObjectSettings/BaseObjectSettings.tsx
13
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
14
+ import { batch } from "@preact/signals-core";
15
+ import * as Function from "effect/Function";
16
+ import * as Option from "effect/Option";
17
+ import * as Schema from "effect/Schema";
18
+ import React, { useCallback, useMemo } from "react";
19
+ import { DXN, Obj, Tag, Type } from "@dxos/echo";
20
+ import { invariant } from "@dxos/invariant";
21
+ import { getSpace } from "@dxos/react-client/echo";
22
+ import { Form, useRefQueryLookupHandler } from "@dxos/react-ui-form";
23
+ var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-space/src/components/ObjectSettings/BaseObjectSettings.tsx";
24
+ var BaseSchema = Schema.Struct({
25
+ // TODO(wittjosiah): Support multiple tags.
26
+ tag: Type.Ref(Tag.Tag).pipe(Schema.optional)
27
+ });
28
+ var TagSchema = Tag.Tag.pipe(Schema.omit("id"));
29
+ var BaseObjectSettings = ({ classNames, children, object }) => {
30
+ var _effect = _useSignals();
31
+ try {
32
+ const space = getSpace(object);
33
+ const handleRefQueryLookup = useRefQueryLookupHandler({
34
+ space
35
+ });
36
+ const formSchema = useMemo(() => {
37
+ return Function.pipe(Obj.getSchema(object), Option.fromNullable, Option.map((schema) => BaseSchema.pipe(Schema.extend(schema))), Option.getOrUndefined);
38
+ }, [
39
+ object
40
+ ]);
41
+ const meta2 = Obj.getMeta(object);
42
+ const tag = meta2.tags?.[0] ? space?.db.ref(DXN.parse(meta2.tags?.[0])) : void 0;
43
+ const values = useMemo(() => ({
44
+ tag,
45
+ ...object
46
+ }), [
47
+ object,
48
+ tag
49
+ ]);
50
+ const handleCreateTag = useCallback((values2) => {
51
+ invariant(space, void 0, {
52
+ F: __dxlog_file,
53
+ L: 59,
54
+ S: void 0,
55
+ A: [
56
+ "space",
57
+ ""
58
+ ]
59
+ });
60
+ const tag2 = space.db.add(Tag.make(values2));
61
+ const meta3 = Obj.getMeta(object);
62
+ meta3.tags = [
63
+ Obj.getDXN(tag2).toString()
64
+ ];
65
+ }, []);
66
+ const handleSave = useCallback(({ tag: tag2, ...values2 }) => {
67
+ batch(() => {
68
+ const meta3 = Obj.getMeta(object);
69
+ const currentTag = meta3.tags?.[0];
70
+ if (tag2 !== void 0 && currentTag !== tag2?.dxn.toString()) {
71
+ meta3.tags = [
72
+ tag2.dxn.toString()
73
+ ];
74
+ }
75
+ Object.entries(values2).forEach(([key, value]) => {
76
+ if (value !== void 0 && value !== object[key]) {
77
+ Object.defineProperty(object, key, {
78
+ value
79
+ });
80
+ }
81
+ });
82
+ });
83
+ }, [
84
+ object
85
+ ]);
86
+ if (!formSchema) {
87
+ return null;
88
+ }
89
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(Form, {
90
+ classNames,
91
+ outerSpacing: false,
92
+ autoSave: true,
93
+ schema: formSchema,
94
+ values,
95
+ createSchema: TagSchema,
96
+ createOptionIcon: "ph--plus--regular",
97
+ createOptionLabel: [
98
+ "add tag label",
99
+ {
100
+ ns: meta.id
101
+ }
102
+ ],
103
+ createInitialValuePath: "label",
104
+ onCreate: handleCreateTag,
105
+ onSave: handleSave,
106
+ onQueryRefOptions: handleRefQueryLookup
107
+ }), children);
108
+ } finally {
109
+ _effect.f();
110
+ }
111
+ };
112
+
113
+ // src/components/ObjectSettings/ObjectSettingsContainer.tsx
114
+ var ObjectSettingsContainer = ({ object, role }) => {
115
+ var _effect = _useSignals2();
116
+ try {
117
+ const data = useMemo2(() => ({
118
+ subject: object
119
+ }), [
120
+ object
121
+ ]);
122
+ return /* @__PURE__ */ React2.createElement(Clipboard.Provider, null, /* @__PURE__ */ React2.createElement(StackItem.Content, {
123
+ toolbar: true
124
+ }, /* @__PURE__ */ React2.createElement(Toolbar.Root, null), /* @__PURE__ */ React2.createElement("div", {
125
+ role: "none",
126
+ className: "overflow-y-auto pli-cardSpacingInline plb-cardSpacingBlock"
127
+ }, /* @__PURE__ */ React2.createElement(BaseObjectSettings, {
128
+ object
129
+ }, /* @__PURE__ */ React2.createElement(Surface, {
130
+ role: "base-object-settings",
131
+ data
132
+ })), /* @__PURE__ */ React2.createElement(Surface, {
133
+ role: "object-settings",
134
+ data
135
+ }))));
136
+ } finally {
137
+ _effect.f();
138
+ }
139
+ };
140
+
141
+ // src/components/ObjectSettings/index.ts
142
+ var ObjectSettings_default = ObjectSettingsContainer;
143
+ export {
144
+ ObjectSettings_default as default
145
+ };
146
+ //# sourceMappingURL=ObjectSettings-UFTKBP7B.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/ObjectSettings/ObjectSettingsContainer.tsx", "../../../src/components/ObjectSettings/BaseObjectSettings.tsx", "../../../src/components/ObjectSettings/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useMemo } from 'react';\n\nimport { Surface } from '@dxos/app-framework';\nimport { type Obj } from '@dxos/echo';\nimport { Clipboard, Toolbar } from '@dxos/react-ui';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { BaseObjectSettings } from './BaseObjectSettings';\n\nexport type ObjectSettingsContainerProps = {\n object: Obj.Any;\n role: string;\n};\n\nexport const ObjectSettingsContainer = ({ object, role }: ObjectSettingsContainerProps) => {\n const data = useMemo(() => ({ subject: object }), [object]);\n\n return (\n <Clipboard.Provider>\n <StackItem.Content toolbar>\n <Toolbar.Root></Toolbar.Root>\n <div role='none' className='overflow-y-auto pli-cardSpacingInline plb-cardSpacingBlock'>\n <BaseObjectSettings object={object}>\n <Surface role='base-object-settings' data={data} />\n </BaseObjectSettings>\n <Surface role='object-settings' data={data} />\n {/* TODO(wittjosiah): Remove? */}\n {/* <AdvancedObjectSettings object={object} /> */}\n </div>\n </StackItem.Content>\n </Clipboard.Provider>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { batch } from '@preact/signals-core';\nimport * as Function from 'effect/Function';\nimport * as Option from 'effect/Option';\nimport * as Schema from 'effect/Schema';\nimport React, { type PropsWithChildren, useCallback, useMemo } from 'react';\n\nimport { DXN, Obj, Tag, Type } from '@dxos/echo';\nimport { invariant } from '@dxos/invariant';\nimport { getSpace } from '@dxos/react-client/echo';\nimport { type ThemedClassName } from '@dxos/react-ui';\nimport { Form, useRefQueryLookupHandler } from '@dxos/react-ui-form';\n\nimport { meta as pluginMeta } from '../../meta';\n\n// TODO(wittjosiah): Would be nice to control order when extending so this isn't always first/last.\nconst BaseSchema = Schema.Struct({\n // TODO(wittjosiah): Support multiple tags.\n tag: Type.Ref(Tag.Tag).pipe(Schema.optional),\n});\n\n// TODO(wittjosiah): Better way to support validation of object schemas?\nconst TagSchema = Tag.Tag.pipe(Schema.omit('id'));\n\nexport type BaseObjectSettingsProps = ThemedClassName<\n PropsWithChildren<{\n object: Obj.Any;\n }>\n>;\n\n// TODO(wittjosiah): Reconcile w/ ObjectDetailsPanel.\nexport const BaseObjectSettings = ({ classNames, children, object }: BaseObjectSettingsProps) => {\n const space = getSpace(object);\n const handleRefQueryLookup = useRefQueryLookupHandler({ space });\n\n const formSchema = useMemo(() => {\n return Function.pipe(\n Obj.getSchema(object),\n Option.fromNullable,\n Option.map((schema) => BaseSchema.pipe(Schema.extend(schema))),\n Option.getOrUndefined,\n );\n }, [object]);\n\n const meta = Obj.getMeta(object);\n const tag = meta.tags?.[0] ? space?.db.ref(DXN.parse(meta.tags?.[0])) : undefined;\n const values = useMemo(\n () => ({\n tag,\n ...object,\n }),\n [object, tag],\n );\n\n const handleCreateTag = useCallback((values: Schema.Schema.Type<typeof TagSchema>) => {\n invariant(space);\n const tag = space.db.add(Tag.make(values));\n const meta = Obj.getMeta(object);\n meta.tags = [Obj.getDXN(tag).toString()];\n }, []);\n\n const handleSave = useCallback(\n ({ tag, ...values }: Schema.Schema.Type<typeof formSchema>) => {\n batch(() => {\n const meta = Obj.getMeta(object);\n const currentTag = meta.tags?.[0];\n if (tag !== undefined && currentTag !== tag?.dxn.toString()) {\n meta.tags = [tag.dxn.toString()];\n }\n\n Object.entries(values).forEach(([key, value]) => {\n if (value !== undefined && value !== object[key as keyof Obj.Any]) {\n Object.defineProperty(object, key, { value });\n }\n });\n });\n },\n [object],\n );\n\n if (!formSchema) {\n return null;\n }\n\n return (\n <>\n <Form\n classNames={classNames}\n outerSpacing={false}\n autoSave\n schema={formSchema}\n values={values}\n createSchema={TagSchema}\n createOptionIcon='ph--plus--regular'\n createOptionLabel={['add tag label', { ns: pluginMeta.id }]}\n createInitialValuePath='label'\n onCreate={handleCreateTag}\n onSave={handleSave}\n onQueryRefOptions={handleRefQueryLookup}\n />\n {children}\n </>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { ObjectSettingsContainer } from './ObjectSettingsContainer';\n\nexport default ObjectSettingsContainer;\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "useMemo", "Surface", "Clipboard", "Toolbar", "StackItem", "batch", "Function", "Option", "Schema", "React", "useCallback", "useMemo", "DXN", "Obj", "Tag", "Type", "invariant", "getSpace", "Form", "useRefQueryLookupHandler", "BaseSchema", "Struct", "tag", "Type", "Ref", "Tag", "pipe", "optional", "TagSchema", "omit", "BaseObjectSettings", "classNames", "children", "object", "space", "getSpace", "handleRefQueryLookup", "useRefQueryLookupHandler", "formSchema", "useMemo", "Obj", "getSchema", "fromNullable", "map", "schema", "extend", "getOrUndefined", "meta", "getMeta", "tags", "db", "ref", "DXN", "parse", "undefined", "values", "handleCreateTag", "useCallback", "invariant", "add", "make", "getDXN", "toString", "handleSave", "batch", "currentTag", "dxn", "Object", "entries", "forEach", "key", "value", "defineProperty", "Form", "outerSpacing", "autoSave", "createSchema", "createOptionIcon", "createOptionLabel", "ns", "pluginMeta", "id", "createInitialValuePath", "onCreate", "onSave", "onQueryRefOptions", "ObjectSettingsContainer", "object", "role", "data", "useMemo", "subject", "React", "Clipboard", "Provider", "StackItem", "Content", "toolbar", "Toolbar", "Root", "div", "className", "BaseObjectSettings", "Surface", "ObjectSettingsContainer"]
7
+ }
@@ -0,0 +1,99 @@
1
+ import {
2
+ meta
3
+ } from "./chunk-VZBIIYFM.mjs";
4
+
5
+ // src/components/RecordMain.tsx
6
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
7
+ import React, { useMemo } from "react";
8
+ import { Surface } from "@dxos/app-framework";
9
+ import { Filter, Ref, Relation } from "@dxos/echo";
10
+ import { getSpace, useQuery } from "@dxos/react-client/echo";
11
+ import { useTranslation } from "@dxos/react-ui";
12
+ import { Masonry } from "@dxos/react-ui-masonry";
13
+ import { StackItem } from "@dxos/react-ui-stack";
14
+ import { mx } from "@dxos/react-ui-theme";
15
+ import { isNonNullable } from "@dxos/util";
16
+ var RecordMain = ({ record }) => {
17
+ var _effect = _useSignals();
18
+ try {
19
+ const { t } = useTranslation(meta.id);
20
+ const space = getSpace(record);
21
+ const data = useMemo(() => ({
22
+ subject: record
23
+ }), [
24
+ record
25
+ ]);
26
+ const objects = useQuery(space, Filter.everything());
27
+ const related = useMemo(() => {
28
+ const relations = objects.filter((obj) => Relation.isRelation(obj));
29
+ const targetObjects = relations.filter((relation) => Relation.getSource(relation) === record).map((relation) => Relation.getTarget(relation));
30
+ const sourceObjects = relations.filter((relation) => Relation.getTarget(relation) === record).map((relation) => Relation.getSource(relation));
31
+ const references = getReferencesFromObject(record);
32
+ const referencedObjects = references.map((ref) => ref.target).filter(isNonNullable);
33
+ const referencingObjects = objects.filter((obj) => {
34
+ const refs = getReferencesFromObject(obj);
35
+ return refs.some((ref) => ref.target === record);
36
+ });
37
+ return [
38
+ ...referencedObjects,
39
+ ...referencingObjects,
40
+ ...targetObjects,
41
+ ...sourceObjects
42
+ ];
43
+ }, [
44
+ record,
45
+ objects
46
+ ]);
47
+ return /* @__PURE__ */ React.createElement(StackItem.Content, {
48
+ classNames: "flex flex-col items-center"
49
+ }, /* @__PURE__ */ React.createElement("div", {
50
+ role: "none",
51
+ className: mx("flex flex-col gap-4 p-6 is-full overflow-y-auto")
52
+ }, /* @__PURE__ */ React.createElement("div", {
53
+ role: "none",
54
+ className: mx("flex flex-col gap-1 card-min-width card-max-width")
55
+ }, /* @__PURE__ */ React.createElement(Surface, {
56
+ role: "section",
57
+ data,
58
+ limit: 1
59
+ })), related.length > 0 && /* @__PURE__ */ React.createElement("div", {
60
+ role: "none",
61
+ className: mx("flex flex-col gap-1", related.length === 1 ? "card-max-width" : "is-full")
62
+ }, /* @__PURE__ */ React.createElement("label", {
63
+ className: "text-description text-sm mbs-2"
64
+ }, t("related objects label")), /* @__PURE__ */ React.createElement(Masonry.Root, {
65
+ items: related,
66
+ render: Card,
67
+ intrinsicHeight: true,
68
+ columnCount: related.length === 1 ? 1 : void 0
69
+ }))));
70
+ } finally {
71
+ _effect.f();
72
+ }
73
+ };
74
+ var Card = ({ data: subject }) => {
75
+ var _effect = _useSignals();
76
+ try {
77
+ const data = useMemo(() => ({
78
+ subject
79
+ }), [
80
+ subject
81
+ ]);
82
+ return /* @__PURE__ */ React.createElement(Surface, {
83
+ role: "card",
84
+ data,
85
+ limit: 1
86
+ });
87
+ } finally {
88
+ _effect.f();
89
+ }
90
+ };
91
+ var getReferencesFromObject = (obj) => {
92
+ return Object.getOwnPropertyNames(obj).map((name) => obj[name]).filter((value) => Ref.isRef(value));
93
+ };
94
+ var RecordMain_default = RecordMain;
95
+ export {
96
+ RecordMain,
97
+ RecordMain_default as default
98
+ };
99
+ //# sourceMappingURL=RecordMain-BCSXTSEB.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/RecordMain.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { useMemo } from 'react';\n\nimport { Surface } from '@dxos/app-framework';\nimport { Filter, type Obj, Ref, Relation } from '@dxos/echo';\nimport { getSpace, useQuery } from '@dxos/react-client/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { Masonry } from '@dxos/react-ui-masonry';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { mx } from '@dxos/react-ui-theme';\nimport { isNonNullable } from '@dxos/util';\n\nimport { meta } from '../meta';\n\nexport type RecordMainProps = {\n record: Obj.Any;\n};\n\nexport const RecordMain = ({ record }: RecordMainProps) => {\n const { t } = useTranslation(meta.id);\n const space = getSpace(record);\n const data = useMemo(() => ({ subject: record }), [record]);\n\n // TODO(wittjosiah): This is a hack. ECHO needs to have a back reference index to easily query for related objects.\n const objects = useQuery(space, Filter.everything());\n const related = useMemo(() => {\n const relations = objects.filter((obj) => Relation.isRelation(obj));\n const targetObjects = relations\n .filter((relation) => Relation.getSource(relation) === record)\n .map((relation) => Relation.getTarget(relation));\n const sourceObjects = relations\n .filter((relation) => Relation.getTarget(relation) === record)\n .map((relation) => Relation.getSource(relation));\n\n const references = getReferencesFromObject(record);\n const referencedObjects = references.map((ref) => ref.target).filter(isNonNullable);\n const referencingObjects = objects.filter((obj) => {\n const refs = getReferencesFromObject(obj);\n return refs.some((ref) => ref.target === record);\n });\n\n return [...referencedObjects, ...referencingObjects, ...targetObjects, ...sourceObjects];\n }, [record, objects]);\n\n return (\n <StackItem.Content classNames='flex flex-col items-center'>\n <div role='none' className={mx('flex flex-col gap-4 p-6 is-full overflow-y-auto')}>\n <div role='none' className={mx('flex flex-col gap-1 card-min-width card-max-width')}>\n <Surface role='section' data={data} limit={1} />\n </div>\n\n {/* TODO(wittjosiah): This should maybe be in a separate stack item. */}\n {related.length > 0 && (\n <div role='none' className={mx('flex flex-col gap-1', related.length === 1 ? 'card-max-width' : 'is-full')}>\n <label className='text-description text-sm mbs-2'>{t('related objects label')}</label>\n <Masonry.Root<Obj.Any>\n items={related}\n render={Card}\n intrinsicHeight\n columnCount={related.length === 1 ? 1 : undefined}\n />\n </div>\n )}\n </div>\n </StackItem.Content>\n );\n};\n\nconst Card = ({ data: subject }: { data: Obj.Any }) => {\n const data = useMemo(() => ({ subject }), [subject]);\n return <Surface role='card' data={data} limit={1} />;\n};\n\nconst getReferencesFromObject = (obj: Obj.Any): Ref.Any[] => {\n return Object.getOwnPropertyNames(obj)\n .map((name) => obj[name as keyof Obj.Any])\n .filter((value) => Ref.isRef(value)) as Ref.Any[];\n};\n\nexport default RecordMain;\n"],
5
+ "mappings": ";;;;;;AAIA,OAAOA,SAASC,eAAe;AAE/B,SAASC,eAAe;AACxB,SAASC,QAAkBC,KAAKC,gBAAgB;AAChD,SAASC,UAAUC,gBAAgB;AACnC,SAASC,sBAAsB;AAC/B,SAASC,eAAe;AACxB,SAASC,iBAAiB;AAC1B,SAASC,UAAU;AACnB,SAASC,qBAAqB;AAQvB,IAAMC,aAAa,CAAC,EAAEC,OAAM,MAAmB;;;AACpD,UAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AACpC,UAAMC,QAAQC,SAASN,MAAAA;AACvB,UAAMO,OAAOC,QAAQ,OAAO;MAAEC,SAAST;IAAO,IAAI;MAACA;KAAO;AAG1D,UAAMU,UAAUC,SAASN,OAAOO,OAAOC,WAAU,CAAA;AACjD,UAAMC,UAAUN,QAAQ,MAAA;AACtB,YAAMO,YAAYL,QAAQM,OAAO,CAACC,QAAQC,SAASC,WAAWF,GAAAA,CAAAA;AAC9D,YAAMG,gBAAgBL,UACnBC,OAAO,CAACK,aAAaH,SAASI,UAAUD,QAAAA,MAAcrB,MAAAA,EACtDuB,IAAI,CAACF,aAAaH,SAASM,UAAUH,QAAAA,CAAAA;AACxC,YAAMI,gBAAgBV,UACnBC,OAAO,CAACK,aAAaH,SAASM,UAAUH,QAAAA,MAAcrB,MAAAA,EACtDuB,IAAI,CAACF,aAAaH,SAASI,UAAUD,QAAAA,CAAAA;AAExC,YAAMK,aAAaC,wBAAwB3B,MAAAA;AAC3C,YAAM4B,oBAAoBF,WAAWH,IAAI,CAACM,QAAQA,IAAIC,MAAM,EAAEd,OAAOe,aAAAA;AACrE,YAAMC,qBAAqBtB,QAAQM,OAAO,CAACC,QAAAA;AACzC,cAAMgB,OAAON,wBAAwBV,GAAAA;AACrC,eAAOgB,KAAKC,KAAK,CAACL,QAAQA,IAAIC,WAAW9B,MAAAA;MAC3C,CAAA;AAEA,aAAO;WAAI4B;WAAsBI;WAAuBZ;WAAkBK;;IAC5E,GAAG;MAACzB;MAAQU;KAAQ;AAEpB,WACE,sBAAA,cAACyB,UAAUC,SAAO;MAACC,YAAW;OAC5B,sBAAA,cAACC,OAAAA;MAAIC,MAAK;MAAOC,WAAWC,GAAG,iDAAA;OAC7B,sBAAA,cAACH,OAAAA;MAAIC,MAAK;MAAOC,WAAWC,GAAG,mDAAA;OAC7B,sBAAA,cAACC,SAAAA;MAAQH,MAAK;MAAUhC;MAAYoC,OAAO;SAI5C7B,QAAQ8B,SAAS,KAChB,sBAAA,cAACN,OAAAA;MAAIC,MAAK;MAAOC,WAAWC,GAAG,uBAAuB3B,QAAQ8B,WAAW,IAAI,mBAAmB,SAAA;OAC9F,sBAAA,cAACC,SAAAA;MAAML,WAAU;OAAkCvC,EAAE,uBAAA,CAAA,GACrD,sBAAA,cAAC6C,QAAQC,MAAI;MACXC,OAAOlC;MACPmC,QAAQC;MACRC,iBAAAA;MACAC,aAAatC,QAAQ8B,WAAW,IAAI,IAAIS;;;;;AAOtD;AAEA,IAAMH,OAAO,CAAC,EAAE3C,MAAME,QAAO,MAAqB;;;AAChD,UAAMF,OAAOC,QAAQ,OAAO;MAAEC;IAAQ,IAAI;MAACA;KAAQ;AACnD,WAAO,sBAAA,cAACiC,SAAAA;MAAQH,MAAK;MAAOhC;MAAYoC,OAAO;;;;;AACjD;AAEA,IAAMhB,0BAA0B,CAACV,QAAAA;AAC/B,SAAOqC,OAAOC,oBAAoBtC,GAAAA,EAC/BM,IAAI,CAACiC,SAASvC,IAAIuC,IAAAA,CAAsB,EACxCxC,OAAO,CAACyC,UAAUC,IAAIC,MAAMF,KAAAA,CAAAA;AACjC;AAEA,IAAA,qBAAe1D;",
6
+ "names": ["React", "useMemo", "Surface", "Filter", "Ref", "Relation", "getSpace", "useQuery", "useTranslation", "Masonry", "StackItem", "mx", "isNonNullable", "RecordMain", "record", "t", "useTranslation", "meta", "id", "space", "getSpace", "data", "useMemo", "subject", "objects", "useQuery", "Filter", "everything", "related", "relations", "filter", "obj", "Relation", "isRelation", "targetObjects", "relation", "getSource", "map", "getTarget", "sourceObjects", "references", "getReferencesFromObject", "referencedObjects", "ref", "target", "isNonNullable", "referencingObjects", "refs", "some", "StackItem", "Content", "classNames", "div", "role", "className", "mx", "Surface", "limit", "length", "label", "Masonry", "Root", "items", "render", "Card", "intrinsicHeight", "columnCount", "undefined", "Object", "getOwnPropertyNames", "name", "value", "Ref", "isRef"]
7
+ }