@dxos/plugin-help 0.8.4-main.f5c0578 → 0.8.4-main.fcc0d83b33

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 (139) hide show
  1. package/dist/lib/browser/chunk-53QC3FTJ.mjs +34 -0
  2. package/dist/lib/browser/chunk-53QC3FTJ.mjs.map +7 -0
  3. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  4. package/dist/lib/browser/chunk-J5LGTIGS.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-RWK34XL5.mjs +31 -0
  6. package/dist/lib/browser/chunk-RWK34XL5.mjs.map +7 -0
  7. package/dist/lib/browser/index.mjs +347 -83
  8. package/dist/lib/browser/index.mjs.map +4 -4
  9. package/dist/lib/browser/meta.json +1 -1
  10. package/dist/lib/browser/meta.mjs +13 -5
  11. package/dist/lib/browser/meta.mjs.map +4 -4
  12. package/dist/lib/browser/operations/index.mjs +13 -0
  13. package/dist/lib/browser/operations/index.mjs.map +7 -0
  14. package/dist/lib/browser/start-JQ2LLVCT.mjs +23 -0
  15. package/dist/lib/browser/start-JQ2LLVCT.mjs.map +7 -0
  16. package/dist/lib/browser/translations.mjs +20 -0
  17. package/dist/lib/browser/translations.mjs.map +7 -0
  18. package/dist/lib/browser/types/index.mjs +4 -4
  19. package/dist/types/src/HelpPlugin.d.ts +3 -2
  20. package/dist/types/src/HelpPlugin.d.ts.map +1 -1
  21. package/dist/types/src/capabilities/app-graph-builder.d.ts +4 -2
  22. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  23. package/dist/types/src/capabilities/index.d.ts +16 -6
  24. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  25. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  26. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  27. package/dist/types/src/capabilities/react-root.d.ts +5 -3
  28. package/dist/types/src/capabilities/react-root.d.ts.map +1 -1
  29. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  30. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  31. package/dist/types/src/capabilities/state.d.ts +11 -2
  32. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  33. package/dist/types/src/components/Shortcuts/Key.d.ts.map +1 -1
  34. package/dist/types/src/components/Shortcuts/ShortcutsHints.d.ts.map +1 -1
  35. package/dist/types/src/components/Shortcuts/ShortcutsSection.d.ts.map +1 -1
  36. package/dist/types/src/components/Shortcuts/index.d.ts +0 -1
  37. package/dist/types/src/components/Shortcuts/index.d.ts.map +1 -1
  38. package/dist/types/src/components/Tooltip/Tooltip.d.ts +9 -9
  39. package/dist/types/src/components/Tooltip/Tooltip.d.ts.map +1 -1
  40. package/dist/types/src/components/WelcomeTour/WelcomeTour.d.ts +1 -1
  41. package/dist/types/src/components/WelcomeTour/WelcomeTour.d.ts.map +1 -1
  42. package/dist/types/src/components/WelcomeTour/WelcomeTour.stories.d.ts +9 -4
  43. package/dist/types/src/components/WelcomeTour/WelcomeTour.stories.d.ts.map +1 -1
  44. package/dist/types/src/constants.d.ts +2 -0
  45. package/dist/types/src/constants.d.ts.map +1 -0
  46. package/dist/types/src/containers/ShortcutsDialogContent/ShortcutsDialogContent.d.ts +3 -0
  47. package/dist/types/src/containers/ShortcutsDialogContent/ShortcutsDialogContent.d.ts.map +1 -0
  48. package/dist/types/src/containers/ShortcutsDialogContent/ShortcutsDialogContent.stories.d.ts +25 -0
  49. package/dist/types/src/containers/ShortcutsDialogContent/ShortcutsDialogContent.stories.d.ts.map +1 -0
  50. package/dist/types/src/containers/ShortcutsDialogContent/index.d.ts +2 -0
  51. package/dist/types/src/containers/ShortcutsDialogContent/index.d.ts.map +1 -0
  52. package/dist/types/src/containers/ShortcutsHints/ShortcutsHints.d.ts +2 -0
  53. package/dist/types/src/containers/ShortcutsHints/ShortcutsHints.d.ts.map +1 -0
  54. package/dist/types/src/containers/ShortcutsHints/index.d.ts +2 -0
  55. package/dist/types/src/containers/ShortcutsHints/index.d.ts.map +1 -0
  56. package/dist/types/src/containers/ShortcutsList/ShortcutsList.d.ts +2 -0
  57. package/dist/types/src/containers/ShortcutsList/ShortcutsList.d.ts.map +1 -0
  58. package/dist/types/src/containers/ShortcutsList/index.d.ts +2 -0
  59. package/dist/types/src/containers/ShortcutsList/index.d.ts.map +1 -0
  60. package/dist/types/src/containers/index.d.ts +5 -0
  61. package/dist/types/src/containers/index.d.ts.map +1 -0
  62. package/dist/types/src/hooks/useHelp.d.ts +1 -1
  63. package/dist/types/src/hooks/useHelp.d.ts.map +1 -1
  64. package/dist/types/src/index.d.ts +2 -3
  65. package/dist/types/src/index.d.ts.map +1 -1
  66. package/dist/types/src/meta.d.ts +2 -3
  67. package/dist/types/src/meta.d.ts.map +1 -1
  68. package/dist/types/src/operations/definitions.d.ts +4 -0
  69. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  70. package/dist/types/src/operations/index.d.ts +4 -0
  71. package/dist/types/src/operations/index.d.ts.map +1 -0
  72. package/dist/types/src/operations/start.d.ts +5 -0
  73. package/dist/types/src/operations/start.d.ts.map +1 -0
  74. package/dist/types/src/translations.d.ts +5 -6
  75. package/dist/types/src/translations.d.ts.map +1 -1
  76. package/dist/types/src/types/capabilities.d.ts +21 -0
  77. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  78. package/dist/types/src/types/index.d.ts +1 -0
  79. package/dist/types/src/types/index.d.ts.map +1 -1
  80. package/dist/types/src/types/schema.d.ts +2 -14
  81. package/dist/types/src/types/schema.d.ts.map +1 -1
  82. package/dist/types/tsconfig.tsbuildinfo +1 -1
  83. package/package.json +61 -44
  84. package/src/HelpPlugin.tsx +22 -49
  85. package/src/capabilities/app-graph-builder.ts +53 -67
  86. package/src/capabilities/index.ts +10 -7
  87. package/src/capabilities/operation-handler.ts +16 -0
  88. package/src/capabilities/react-root.tsx +28 -25
  89. package/src/capabilities/react-surface.tsx +28 -22
  90. package/src/capabilities/state.ts +19 -16
  91. package/src/components/Shortcuts/ShortcutsHints.tsx +13 -5
  92. package/src/components/Shortcuts/ShortcutsList.tsx +5 -5
  93. package/src/components/Shortcuts/ShortcutsSection.tsx +1 -3
  94. package/src/components/Shortcuts/index.ts +0 -1
  95. package/src/components/Shortcuts/styles.ts +3 -3
  96. package/src/components/Tooltip/Tooltip.tsx +4 -5
  97. package/src/components/WelcomeTour/WelcomeTour.stories.tsx +21 -16
  98. package/src/components/WelcomeTour/WelcomeTour.tsx +18 -18
  99. package/src/constants.ts +7 -0
  100. package/src/containers/ShortcutsDialogContent/ShortcutsDialogContent.stories.tsx +39 -0
  101. package/src/containers/ShortcutsDialogContent/ShortcutsDialogContent.tsx +28 -0
  102. package/src/containers/ShortcutsDialogContent/index.ts +5 -0
  103. package/src/containers/ShortcutsHints/ShortcutsHints.tsx +5 -0
  104. package/src/containers/ShortcutsHints/index.ts +5 -0
  105. package/src/containers/ShortcutsList/ShortcutsList.tsx +5 -0
  106. package/src/containers/ShortcutsList/index.ts +5 -0
  107. package/src/containers/index.ts +9 -0
  108. package/src/hooks/useHelp.tsx +1 -1
  109. package/src/index.ts +2 -3
  110. package/src/meta.ts +8 -6
  111. package/src/operations/definitions.ts +19 -0
  112. package/src/operations/index.ts +9 -0
  113. package/src/operations/start.ts +21 -0
  114. package/src/translations.ts +5 -5
  115. package/src/types/capabilities.ts +24 -0
  116. package/src/types/index.ts +1 -0
  117. package/src/types/schema.ts +2 -12
  118. package/dist/lib/browser/app-graph-builder-TUTK2ONB.mjs +0 -79
  119. package/dist/lib/browser/app-graph-builder-TUTK2ONB.mjs.map +0 -7
  120. package/dist/lib/browser/chunk-3Y4CMOZP.mjs +0 -13
  121. package/dist/lib/browser/chunk-3Y4CMOZP.mjs.map +0 -7
  122. package/dist/lib/browser/chunk-GIDPSFGY.mjs +0 -409
  123. package/dist/lib/browser/chunk-GIDPSFGY.mjs.map +0 -7
  124. package/dist/lib/browser/chunk-J2SJSGSX.mjs +0 -34
  125. package/dist/lib/browser/chunk-J2SJSGSX.mjs.map +0 -7
  126. package/dist/lib/browser/chunk-LDRUZNSN.mjs +0 -16
  127. package/dist/lib/browser/chunk-LDRUZNSN.mjs.map +0 -7
  128. package/dist/lib/browser/react-root-5GSVXKQD.mjs +0 -34
  129. package/dist/lib/browser/react-root-5GSVXKQD.mjs.map +0 -7
  130. package/dist/lib/browser/react-surface-V7U4IDJV.mjs +0 -36
  131. package/dist/lib/browser/react-surface-V7U4IDJV.mjs.map +0 -7
  132. package/dist/lib/browser/state-IXBTB3WH.mjs +0 -29
  133. package/dist/lib/browser/state-IXBTB3WH.mjs.map +0 -7
  134. package/dist/types/src/capabilities/capabilities.d.ts +0 -10
  135. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  136. package/dist/types/src/components/Shortcuts/ShortcutsDialog.d.ts +0 -4
  137. package/dist/types/src/components/Shortcuts/ShortcutsDialog.d.ts.map +0 -1
  138. package/src/capabilities/capabilities.ts +0 -13
  139. package/src/components/Shortcuts/ShortcutsDialog.tsx +0 -35
package/package.json CHANGED
@@ -1,13 +1,27 @@
1
1
  {
2
2
  "name": "@dxos/plugin-help",
3
- "version": "0.8.4-main.f5c0578",
3
+ "version": "0.8.4-main.fcc0d83b33",
4
4
  "description": "Help plugin.",
5
5
  "homepage": "https://dxos.org",
6
6
  "bugs": "https://github.com/dxos/dxos/issues",
7
+ "repository": {
8
+ "type": "git",
9
+ "url": "https://github.com/dxos/dxos"
10
+ },
7
11
  "license": "MIT",
8
12
  "author": "DXOS.org",
9
13
  "sideEffects": true,
10
14
  "type": "module",
15
+ "imports": {
16
+ "#capabilities": "./src/capabilities/index.ts",
17
+ "#components": "./src/components/index.ts",
18
+ "#containers": "./src/containers/index.ts",
19
+ "#hooks": "./src/hooks/index.ts",
20
+ "#meta": "./src/meta.ts",
21
+ "#operations": "./src/operations/index.ts",
22
+ "#translations": "./src/translations.ts",
23
+ "#types": "./src/types/index.ts"
24
+ },
11
25
  "exports": {
12
26
  ".": {
13
27
  "source": "./src/index.ts",
@@ -19,6 +33,17 @@
19
33
  "types": "./dist/types/src/meta.d.ts",
20
34
  "browser": "./dist/lib/browser/meta.mjs"
21
35
  },
36
+ "./operations": {
37
+ "source": "./src/operations/index.ts",
38
+ "types": "./dist/types/src/operations/index.d.ts",
39
+ "browser": "./dist/lib/browser/operations/index.mjs"
40
+ },
41
+ "./translations": {
42
+ "source": "./src/translations.ts",
43
+ "types": "./dist/types/src/translations.d.ts",
44
+ "browser": "./dist/lib/browser/translations.mjs",
45
+ "node": "./dist/lib/node-esm/translations.mjs"
46
+ },
22
47
  "./types": {
23
48
  "source": "./src/types/index.ts",
24
49
  "types": "./dist/types/src/types/index.d.ts",
@@ -26,61 +51,53 @@
26
51
  }
27
52
  },
28
53
  "types": "dist/types/src/index.d.ts",
29
- "typesVersions": {
30
- "*": {
31
- "meta": [
32
- "dist/types/src/meta.d.ts"
33
- ],
34
- "types": [
35
- "dist/types/src/types/index.d.ts"
36
- ]
37
- }
38
- },
39
54
  "files": [
40
55
  "dist",
41
56
  "src"
42
57
  ],
43
58
  "dependencies": {
44
- "@fluentui/react-tabster": "^9.24.2",
45
- "@preact-signals/safe-react": "^0.9.0",
59
+ "@effect-atom/atom": "^0.5.1",
60
+ "@fluentui/react-tabster": "9.26.11",
46
61
  "react-joyride": "^2.7.2",
47
- "@dxos/app-framework": "0.8.4-main.f5c0578",
48
- "@dxos/debug": "0.8.4-main.f5c0578",
49
- "@dxos/app-graph": "0.8.4-main.f5c0578",
50
- "@dxos/echo": "0.8.4-main.f5c0578",
51
- "@dxos/echo-schema": "0.8.4-main.f5c0578",
52
- "@dxos/keyboard": "0.8.4-main.f5c0578",
53
- "@dxos/live-object": "0.8.4-main.f5c0578",
54
- "@dxos/local-storage": "0.8.4-main.f5c0578",
55
- "@dxos/plugin-client": "0.8.4-main.f5c0578",
56
- "@dxos/plugin-graph": "0.8.4-main.f5c0578",
57
- "@dxos/plugin-space": "0.8.4-main.f5c0578",
58
- "@dxos/react-client": "0.8.4-main.f5c0578"
62
+ "@dxos/app-graph": "0.8.4-main.fcc0d83b33",
63
+ "@dxos/app-framework": "0.8.4-main.fcc0d83b33",
64
+ "@dxos/compute": "0.8.4-main.fcc0d83b33",
65
+ "@dxos/app-toolkit": "0.8.4-main.fcc0d83b33",
66
+ "@dxos/effect": "0.8.4-main.fcc0d83b33",
67
+ "@dxos/keyboard": "0.8.4-main.fcc0d83b33",
68
+ "@dxos/debug": "0.8.4-main.fcc0d83b33",
69
+ "@dxos/echo": "0.8.4-main.fcc0d83b33",
70
+ "@dxos/plugin-graph": "0.8.4-main.fcc0d83b33",
71
+ "@dxos/plugin-space": "0.8.4-main.fcc0d83b33",
72
+ "@dxos/plugin-client": "0.8.4-main.fcc0d83b33",
73
+ "@dxos/react-client": "0.8.4-main.fcc0d83b33",
74
+ "@dxos/util": "0.8.4-main.fcc0d83b33"
59
75
  },
60
76
  "devDependencies": {
61
- "@effect-rx/rx-react": "0.38.0",
62
- "@effect/platform": "0.90.2",
63
- "@types/react": "~18.2.0",
64
- "@types/react-dom": "~18.2.0",
65
- "effect": "3.17.7",
66
- "react": "~18.2.0",
67
- "react-dom": "~18.2.0",
77
+ "@effect-atom/atom-react": "^0.5.0",
78
+ "@effect/platform": "0.94.4",
79
+ "@types/react": "~19.2.7",
80
+ "@types/react-dom": "~19.2.3",
81
+ "effect": "3.20.0",
82
+ "react": "~19.2.3",
83
+ "react-dom": "~19.2.3",
68
84
  "react-floater": "0.7.9",
69
85
  "type-fest": "4.10.1",
70
- "vite": "5.4.7",
71
- "@dxos/random": "0.8.4-main.f5c0578",
72
- "@dxos/react-ui": "0.8.4-main.f5c0578",
73
- "@dxos/react-ui-theme": "0.8.4-main.f5c0578",
74
- "@dxos/storybook-utils": "0.8.4-main.f5c0578"
86
+ "vite": "^8.0.10",
87
+ "@dxos/plugin-testing": "0.8.4-main.fcc0d83b33",
88
+ "@dxos/ui-theme": "0.8.4-main.fcc0d83b33",
89
+ "@dxos/random": "0.8.4-main.fcc0d83b33",
90
+ "@dxos/storybook-utils": "0.8.4-main.fcc0d83b33",
91
+ "@dxos/react-ui": "0.8.4-main.fcc0d83b33"
75
92
  },
76
93
  "peerDependencies": {
77
- "@effect-rx/rx-react": "^0.34.1",
78
- "@effect/platform": "^0.80.12",
79
- "effect": "^3.13.3",
80
- "react": "~18.2.0",
81
- "react-dom": "~18.2.0",
82
- "@dxos/react-ui": "0.8.4-main.f5c0578",
83
- "@dxos/react-ui-theme": "0.8.4-main.f5c0578"
94
+ "@effect-atom/atom-react": "^0.5.0",
95
+ "@effect/platform": "0.94.4",
96
+ "effect": "3.20.0",
97
+ "react": "~19.2.3",
98
+ "react-dom": "~19.2.3",
99
+ "@dxos/react-ui": "0.8.4-main.fcc0d83b33",
100
+ "@dxos/ui-theme": "0.8.4-main.fcc0d83b33"
84
101
  },
85
102
  "publishConfig": {
86
103
  "access": "public"
@@ -2,56 +2,29 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { Capabilities, Events, contributes, createResolver, defineModule, definePlugin } from '@dxos/app-framework';
5
+ import { ActivationEvents, Plugin } from '@dxos/app-framework';
6
+ import { AppPlugin } from '@dxos/app-toolkit';
6
7
 
7
- import { AppGraphBuilder, HelpState, ReactRoot, ReactSurface } from './capabilities';
8
- import { HelpCapabilities } from './capabilities/capabilities';
9
- import { meta } from './meta';
10
- import { translations } from './translations';
11
- import { HelpAction, type Step } from './types';
8
+ import { AppGraphBuilder, HelpState, OperationHandler, ReactRoot, ReactSurface } from '#capabilities';
9
+ import { meta } from '#meta';
10
+ import { translations } from '#translations';
11
+ import { type Step } from '#types';
12
12
 
13
13
  export type HelpPluginOptions = { steps?: Step[] };
14
14
 
15
- export const HelpPlugin = ({ steps = [] }: HelpPluginOptions) =>
16
- definePlugin(meta, [
17
- defineModule({
18
- id: `${meta.id}/module/state`,
19
- activatesOn: Events.Startup,
20
- activate: HelpState,
21
- }),
22
- defineModule({
23
- id: `${meta.id}/module/translations`,
24
- activatesOn: Events.SetupTranslations,
25
- activate: () => contributes(Capabilities.Translations, translations),
26
- }),
27
- defineModule({
28
- id: `${meta.id}/module/react-root`,
29
- activatesOn: Events.Startup,
30
- activate: () => ReactRoot(steps),
31
- }),
32
- defineModule({
33
- id: `${meta.id}/module/react-surface`,
34
- activatesOn: Events.SetupReactSurface,
35
- activate: ReactSurface,
36
- }),
37
- defineModule({
38
- id: `${meta.id}/module/intent-resolver`,
39
- activatesOn: Events.SetupIntentResolver,
40
- activate: (context) =>
41
- contributes(
42
- Capabilities.IntentResolver,
43
- createResolver({
44
- intent: HelpAction.Start,
45
- resolve: () => {
46
- const state = context.getCapability(HelpCapabilities.MutableState);
47
- state.running = true;
48
- },
49
- }),
50
- ),
51
- }),
52
- defineModule({
53
- id: `${meta.id}/module/app-graph-builder`,
54
- activatesOn: Events.SetupAppGraph,
55
- activate: AppGraphBuilder,
56
- }),
57
- ]);
15
+ export const HelpPlugin = Plugin.define<HelpPluginOptions>(meta).pipe(
16
+ AppPlugin.addAppGraphModule({ activate: AppGraphBuilder }),
17
+ AppPlugin.addOperationHandlerModule({ activate: OperationHandler }),
18
+ AppPlugin.addSurfaceModule({ activate: ReactSurface }),
19
+ AppPlugin.addTranslationsModule({ translations }),
20
+ Plugin.addModule({
21
+ activatesOn: ActivationEvents.Startup,
22
+ activate: HelpState,
23
+ }),
24
+ Plugin.addModule(({ steps = [] }) => ({
25
+ id: 'react-root',
26
+ activatesOn: ActivationEvents.Startup,
27
+ activate: () => ReactRoot(steps),
28
+ })),
29
+ Plugin.make,
30
+ );
@@ -2,76 +2,62 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { Rx } from '@effect-rx/rx-react';
6
- import { Option, pipe } from 'effect';
5
+ import * as Effect from 'effect/Effect';
7
6
 
8
- import { Capabilities, LayoutAction, type PluginContext, contributes, createIntent } from '@dxos/app-framework';
9
- import { createExtension } from '@dxos/app-graph';
7
+ import { Capabilities, Capability } from '@dxos/app-framework';
8
+ import { GraphBuilder, Node, NodeMatcher } from '@dxos/app-graph';
9
+ import { AppCapabilities, LayoutOperation } from '@dxos/app-toolkit';
10
+ import { Operation } from '@dxos/compute';
10
11
 
11
- import { SHORTCUTS_DIALOG } from '../components';
12
- import { HELP_PLUGIN } from '../meta';
13
- import { HelpAction } from '../types';
12
+ import { meta } from '#meta';
13
+ import { HelpOperation } from '#operations';
14
+ import { HelpCapabilities } from '#types';
14
15
 
15
- import { HelpCapabilities } from './capabilities';
16
+ import { SHORTCUTS_DIALOG } from '../constants';
16
17
 
17
- export default (context: PluginContext) =>
18
- contributes(
19
- Capabilities.AppGraphBuilder,
20
- createExtension({
21
- id: HELP_PLUGIN,
22
- actions: (node) =>
23
- Rx.make((get) =>
24
- pipe(
25
- get(node),
26
- Option.flatMap((node) => (node.id === 'root' ? Option.some(node) : Option.none())),
27
- Option.map(() => [
28
- {
29
- id: HelpAction.Start._tag,
30
- data: async () => {
31
- const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
32
- const state = context.getCapability(HelpCapabilities.MutableState);
33
- state.showHints = true;
34
- await dispatch(createIntent(HelpAction.Start));
35
- },
36
- properties: {
37
- label: ['open help tour', { ns: HELP_PLUGIN }],
38
- icon: 'ph--info--regular',
39
- keyBinding: {
40
- macos: 'shift+meta+/',
41
- // TODO(wittjosiah): Test on windows to see if it behaves the same as linux.
42
- windows: 'shift+ctrl+/',
43
- linux: 'shift+ctrl+?',
44
- },
45
- testId: 'helpPlugin.openHelp',
46
- },
18
+ export default Capability.makeModule(
19
+ Effect.fnUntraced(function* () {
20
+ const extensions = yield* GraphBuilder.createExtension({
21
+ id: 'root',
22
+ match: NodeMatcher.whenRoot,
23
+ actions: () =>
24
+ Effect.succeed([
25
+ Node.makeAction({
26
+ id: HelpOperation.Start.meta.key,
27
+ data: Effect.fnUntraced(function* () {
28
+ yield* Capabilities.updateAtomValue(HelpCapabilities.State, (s) => ({ ...s, showHints: true }));
29
+ yield* Operation.invoke(HelpOperation.Start);
30
+ }),
31
+ properties: {
32
+ label: ['open-help-tour.message', { ns: meta.id }],
33
+ icon: 'ph--info--regular',
34
+ keyBinding: {
35
+ macos: 'shift+meta+/',
36
+ windows: 'shift+ctrl+/',
37
+ linux: 'shift+ctrl+?',
47
38
  },
48
- {
49
- id: 'dxos.org/plugin/help/open-shortcuts',
50
- data: async () => {
51
- const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
52
- const state = context.getCapability(HelpCapabilities.MutableState);
53
- state.showHints = true;
54
- await dispatch(
55
- createIntent(LayoutAction.UpdateDialog, {
56
- part: 'dialog',
57
- subject: SHORTCUTS_DIALOG,
58
- options: {
59
- blockAlign: 'center',
60
- },
61
- }),
62
- );
63
- },
64
- properties: {
65
- label: ['open shortcuts label', { ns: HELP_PLUGIN }],
66
- icon: 'ph--keyboard--regular',
67
- keyBinding: {
68
- macos: 'meta+ctrl+/',
69
- },
70
- },
39
+ testId: 'helpPlugin.openHelp',
40
+ },
41
+ }),
42
+ Node.makeAction({
43
+ id: 'open-shortcuts',
44
+ data: Effect.fnUntraced(function* () {
45
+ yield* Capabilities.updateAtomValue(HelpCapabilities.State, (s) => ({ ...s, showHints: true }));
46
+ yield* Operation.invoke(LayoutOperation.UpdateDialog, {
47
+ subject: SHORTCUTS_DIALOG,
48
+ });
49
+ }),
50
+ properties: {
51
+ label: ['open-shortcuts.label', { ns: meta.id }],
52
+ icon: 'ph--keyboard--regular',
53
+ keyBinding: {
54
+ macos: 'meta+ctrl+/',
71
55
  },
72
- ]),
73
- Option.getOrElse(() => []),
74
- ),
75
- ),
76
- }),
77
- );
56
+ },
57
+ }),
58
+ ]),
59
+ });
60
+
61
+ return Capability.contributes(AppCapabilities.AppGraphBuilder, extensions);
62
+ }),
63
+ );
@@ -2,11 +2,14 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { lazy } from '@dxos/app-framework';
5
+ import { Capability } from '@dxos/app-framework';
6
+ import { OperationHandlerSet } from '@dxos/compute';
6
7
 
7
- export const AppGraphBuilder = lazy(() => import('./app-graph-builder'));
8
- export const ReactRoot = lazy(() => import('./react-root'));
9
- export const ReactSurface = lazy(() => import('./react-surface'));
10
- export const HelpState = lazy(() => import('./state'));
11
-
12
- export * from './capabilities';
8
+ export const AppGraphBuilder = Capability.lazy('AppGraphBuilder', () => import('./app-graph-builder'));
9
+ export const OperationHandler = Capability.lazy<OperationHandlerSet.OperationHandlerSet>(
10
+ 'OperationHandler',
11
+ () => import('./operation-handler'),
12
+ );
13
+ export const ReactRoot = Capability.lazy('ReactRoot', () => import('./react-root'));
14
+ export const ReactSurface = Capability.lazy('ReactSurface', () => import('./react-surface'));
15
+ export const HelpState = Capability.lazy('HelpState', () => import('./state'));
@@ -0,0 +1,16 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+
7
+ import { Capabilities, Capability } from '@dxos/app-framework';
8
+ import type { OperationHandlerSet } from '@dxos/compute';
9
+
10
+ import { HelpOperationHandlerSet } from '#operations';
11
+
12
+ export default Capability.makeModule<OperationHandlerSet.OperationHandlerSet>(
13
+ Effect.fnUntraced(function* () {
14
+ return Capability.contributes(Capabilities.OperationHandler, HelpOperationHandlerSet);
15
+ }),
16
+ );
@@ -2,32 +2,35 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
+ import * as Effect from 'effect/Effect';
5
6
  import React from 'react';
6
7
 
7
- import { Capabilities, contributes, useCapability } from '@dxos/app-framework';
8
+ import { Capabilities, Capability } from '@dxos/app-framework';
9
+ import { useAtomCapabilityState } from '@dxos/app-framework/ui';
8
10
 
9
- import { WelcomeTour } from '../components';
10
- import { HELP_PLUGIN } from '../meta';
11
- import { type Step } from '../types';
11
+ import { WelcomeTour } from '#components';
12
+ import { meta } from '#meta';
13
+ import { HelpCapabilities, type Step } from '#types';
12
14
 
13
- import { HelpCapabilities } from './capabilities';
14
-
15
- export default (steps: Step[]) =>
16
- contributes(Capabilities.ReactRoot, {
17
- id: HELP_PLUGIN,
18
- root: () => {
19
- const state = useCapability(HelpCapabilities.MutableState);
20
- return (
21
- <WelcomeTour
22
- steps={steps}
23
- running={state.running}
24
- onRunningChanged={(newState) => {
25
- state.running = newState;
26
- if (!newState) {
27
- state.showHints = false;
28
- }
29
- }}
30
- />
31
- );
32
- },
33
- });
15
+ export default Capability.makeModule(
16
+ Effect.fnUntraced(function* (steps?: Step[]) {
17
+ return Capability.contributes(Capabilities.ReactRoot, {
18
+ id: meta.id,
19
+ root: () => {
20
+ const [state, updateState] = useAtomCapabilityState(HelpCapabilities.State);
21
+ return (
22
+ <WelcomeTour
23
+ steps={steps ?? []}
24
+ running={state.running}
25
+ onRunningChanged={(newState) => {
26
+ updateState((s) => ({ ...s, running: newState }));
27
+ if (!newState) {
28
+ updateState((s) => ({ ...s, showHints: false }));
29
+ }
30
+ }}
31
+ />
32
+ );
33
+ },
34
+ });
35
+ }),
36
+ );
@@ -2,29 +2,35 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
+ import * as Effect from 'effect/Effect';
5
6
  import React from 'react';
6
7
 
7
- import { Capabilities, contributes, createSurface } from '@dxos/app-framework';
8
+ import { Capabilities, Capability } from '@dxos/app-framework';
9
+ import { Surface } from '@dxos/app-framework/ui';
10
+ import { AppSurface } from '@dxos/app-toolkit/ui';
8
11
 
9
- import { SHORTCUTS_DIALOG, ShortcutsDialogContent, ShortcutsHints, ShortcutsList } from '../components';
10
- import { HELP_PLUGIN } from '../meta';
12
+ import { ShortcutsDialogContent, ShortcutsHints, ShortcutsList } from '#containers';
11
13
 
12
- export default () =>
13
- contributes(Capabilities.ReactSurface, [
14
- createSurface({
15
- id: `${HELP_PLUGIN}/hints`,
16
- role: 'hints',
17
- component: () => <ShortcutsHints />,
18
- }),
19
- createSurface({
20
- id: `${HELP_PLUGIN}/keyshortcuts`,
21
- role: 'keyshortcuts',
22
- component: () => <ShortcutsList />,
23
- }),
24
- createSurface({
25
- id: SHORTCUTS_DIALOG,
26
- role: 'dialog',
27
- filter: (data): data is any => data.component === SHORTCUTS_DIALOG,
28
- component: () => <ShortcutsDialogContent />,
29
- }),
30
- ]);
14
+ import { SHORTCUTS_DIALOG } from '../constants';
15
+
16
+ export default Capability.makeModule(() =>
17
+ Effect.succeed(
18
+ Capability.contributes(Capabilities.ReactSurface, [
19
+ Surface.create({
20
+ id: 'hints',
21
+ role: 'hints',
22
+ component: () => <ShortcutsHints />,
23
+ }),
24
+ Surface.create({
25
+ id: 'keyshortcuts',
26
+ role: 'keyshortcuts',
27
+ component: () => <ShortcutsList />,
28
+ }),
29
+ Surface.create({
30
+ id: SHORTCUTS_DIALOG,
31
+ filter: AppSurface.component(AppSurface.Dialog, SHORTCUTS_DIALOG),
32
+ component: () => <ShortcutsDialogContent />,
33
+ }),
34
+ ]),
35
+ ),
36
+ );
@@ -2,23 +2,26 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { contributes } from '@dxos/app-framework';
6
- import { LocalStorageStore } from '@dxos/local-storage';
5
+ import * as Effect from 'effect/Effect';
7
6
 
8
- import { HELP_PLUGIN } from '../meta';
7
+ import { Capability } from '@dxos/app-framework';
8
+ import { createKvsStore } from '@dxos/effect';
9
9
 
10
- import { HelpCapabilities } from './capabilities';
10
+ import { meta } from '#meta';
11
+ import { HelpCapabilities } from '#types';
11
12
 
12
- export default () => {
13
- const state = new LocalStorageStore<HelpCapabilities.State>(HELP_PLUGIN, {
14
- running: false,
15
- showHints: true,
16
- showWelcome: true,
17
- });
13
+ export default Capability.makeModule(() =>
14
+ Effect.sync(() => {
15
+ const stateAtom = createKvsStore({
16
+ key: meta.id,
17
+ schema: HelpCapabilities.StateSchema,
18
+ defaultValue: () => ({
19
+ running: false,
20
+ showHints: true,
21
+ showWelcome: true,
22
+ }),
23
+ });
18
24
 
19
- state
20
- .prop({ key: 'showHints', type: LocalStorageStore.bool() })
21
- .prop({ key: 'showWelcome', type: LocalStorageStore.bool() });
22
-
23
- return contributes(HelpCapabilities.State, state.values);
24
- };
25
+ return Capability.contributes(HelpCapabilities.State, stateAtom);
26
+ }),
27
+ );
@@ -5,12 +5,13 @@
5
5
  import React from 'react';
6
6
 
7
7
  import { type KeyBinding, Keyboard } from '@dxos/keyboard';
8
- import { Button, Icon, toLocalizedString, useTranslation } from '@dxos/react-ui';
8
+ import { IconButton, toLocalizedString, useTranslation } from '@dxos/react-ui';
9
+ import { osTranslations } from '@dxos/ui-theme';
9
10
 
10
11
  import { Key } from './Key';
11
12
 
12
13
  const Shortcut = ({ binding }: { binding: KeyBinding }) => {
13
- const { t } = useTranslation('os');
14
+ const { t } = useTranslation(osTranslations);
14
15
  return (
15
16
  <div role='none' className='flex items-center gap-2 whitespace-nowrap'>
16
17
  <Key binding={binding.shortcut} />
@@ -31,9 +32,16 @@ export const ShortcutsHints = ({ onClose }: { onClose?: () => void }) => {
31
32
  <Shortcut key={binding.shortcut} binding={binding} />
32
33
  ))}
33
34
  {onClose && (
34
- <Button variant='ghost' classNames='p-0 cursor-pointer' onClick={onClose}>
35
- <Icon icon='ph--x--regular' size={4} />
36
- </Button>
35
+ <IconButton
36
+ icon='ph--x--regular'
37
+ size={4}
38
+ label='Close'
39
+ iconOnly
40
+ noTooltip
41
+ variant='ghost'
42
+ classNames='p-0 cursor-pointer'
43
+ onClick={onClose}
44
+ />
37
45
  )}
38
46
  </div>
39
47
  );
@@ -6,14 +6,14 @@ import React, { Fragment } from 'react';
6
6
 
7
7
  import { Keyboard } from '@dxos/keyboard';
8
8
  import { toLocalizedString, useTranslation } from '@dxos/react-ui';
9
- import { mx } from '@dxos/react-ui-theme';
9
+ import { mx } from '@dxos/ui-theme';
10
10
 
11
- import { HELP_PLUGIN } from '../../meta';
11
+ import { meta } from '#meta';
12
12
 
13
13
  import { Key } from './Key';
14
14
 
15
15
  export const ShortcutsList = () => {
16
- const { t } = useTranslation(HELP_PLUGIN);
16
+ const { t } = useTranslation(meta.id);
17
17
  const bindings = Keyboard.singleton.getBindings();
18
18
 
19
19
  // TODO(burdon): Get shortcuts from TextEditor.
@@ -22,11 +22,11 @@ export const ShortcutsList = () => {
22
22
  });
23
23
 
24
24
  return (
25
- <dl className={mx('is-fit grid grid-cols-[min-content_minmax(12rem,1fr)] gap-2 mlb-4 text-subdued select-none')}>
25
+ <dl className={mx('w-fit grid grid-cols-[min-content_minmax(12rem,1fr)] gap-2 my-4 text-subdued select-none')}>
26
26
  {bindings.map((binding, i) => (
27
27
  <Fragment key={i}>
28
28
  <Key binding={binding.shortcut} />
29
- <span role='definition' className='mis-4' aria-labelledby={binding.shortcut}>
29
+ <span role='definition' className='ms-4' aria-labelledby={binding.shortcut}>
30
30
  {toLocalizedString(binding.data, t)}
31
31
  </span>
32
32
  </Fragment>
@@ -4,13 +4,11 @@
4
4
 
5
5
  import React from 'react';
6
6
 
7
- import { descriptionText } from '@dxos/react-ui-theme';
8
-
9
7
  import { ShortcutsList } from './ShortcutsList';
10
8
 
11
9
  export const ShortcutsSection = () => {
12
10
  return (
13
- <section className={descriptionText}>
11
+ <section className='text-description'>
14
12
  <ShortcutsList />
15
13
  </section>
16
14
  );