@dxos/plugin-help 0.8.4-main.bc674ce → 0.8.4-main.c351d160a8

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 (96) hide show
  1. package/dist/lib/browser/ShortcutsDialogContent-SFEN5YKG.mjs +36 -0
  2. package/dist/lib/browser/ShortcutsDialogContent-SFEN5YKG.mjs.map +7 -0
  3. package/dist/lib/browser/ShortcutsHints-SUH2FE3T.mjs +12 -0
  4. package/dist/lib/browser/ShortcutsHints-SUH2FE3T.mjs.map +7 -0
  5. package/dist/lib/browser/ShortcutsList-4YPEJM33.mjs +12 -0
  6. package/dist/lib/browser/ShortcutsList-4YPEJM33.mjs.map +7 -0
  7. package/dist/lib/browser/{app-graph-builder-DX3VXARQ.mjs → app-graph-builder-5RXPFQPI.mjs} +12 -12
  8. package/dist/lib/browser/app-graph-builder-5RXPFQPI.mjs.map +7 -0
  9. package/dist/lib/browser/{chunk-TS66J4C6.mjs → chunk-HMLZFBYY.mjs} +5 -5
  10. package/dist/lib/browser/{chunk-TS66J4C6.mjs.map → chunk-HMLZFBYY.mjs.map} +1 -1
  11. package/dist/lib/browser/chunk-P34WCEMS.mjs +11 -0
  12. package/dist/lib/browser/chunk-P34WCEMS.mjs.map +7 -0
  13. package/dist/lib/browser/{chunk-IM2QVQOH.mjs → chunk-TEXIV2IJ.mjs} +2 -2
  14. package/dist/lib/browser/{chunk-IM2QVQOH.mjs.map → chunk-TEXIV2IJ.mjs.map} +1 -1
  15. package/dist/lib/browser/{chunk-W5XAZM46.mjs → chunk-VGW5FGD7.mjs} +70 -95
  16. package/dist/lib/browser/chunk-VGW5FGD7.mjs.map +7 -0
  17. package/dist/lib/browser/index.mjs +27 -26
  18. package/dist/lib/browser/index.mjs.map +3 -3
  19. package/dist/lib/browser/meta.json +1 -1
  20. package/dist/lib/browser/meta.mjs +1 -1
  21. package/dist/lib/browser/{react-root-SZRF6EXG.mjs → react-root-JBHEZA5U.mjs} +7 -7
  22. package/dist/lib/browser/react-root-JBHEZA5U.mjs.map +7 -0
  23. package/dist/lib/browser/react-surface-W5S45O6Y.mjs +42 -0
  24. package/dist/lib/browser/react-surface-W5S45O6Y.mjs.map +7 -0
  25. package/dist/lib/browser/{state-VRPLKT3F.mjs → state-SEPP77HO.mjs} +3 -3
  26. package/dist/lib/browser/types/index.mjs +2 -2
  27. package/dist/types/src/HelpPlugin.d.ts.map +1 -1
  28. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts +1 -1
  29. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +1 -1
  30. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +2 -2
  31. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +1 -1
  32. package/dist/types/src/capabilities/react-root/index.d.ts +1 -1
  33. package/dist/types/src/capabilities/react-root/react-root.d.ts +1 -1
  34. package/dist/types/src/capabilities/react-root/react-root.d.ts.map +1 -1
  35. package/dist/types/src/capabilities/react-surface/index.d.ts +1 -1
  36. package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -1
  37. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +2 -2
  38. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -1
  39. package/dist/types/src/capabilities/state/state.d.ts +1 -1
  40. package/dist/types/src/components/Shortcuts/ShortcutsSection.d.ts.map +1 -1
  41. package/dist/types/src/components/Shortcuts/index.d.ts +0 -1
  42. package/dist/types/src/components/Shortcuts/index.d.ts.map +1 -1
  43. package/dist/types/src/components/WelcomeTour/WelcomeTour.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/{components/Shortcuts/ShortcutsDialog.d.ts → containers/ShortcutsDialogContent/ShortcutsDialogContent.d.ts} +1 -2
  47. package/dist/types/src/containers/ShortcutsDialogContent/ShortcutsDialogContent.d.ts.map +1 -0
  48. package/dist/types/src/containers/ShortcutsDialogContent/index.d.ts +3 -0
  49. package/dist/types/src/containers/ShortcutsDialogContent/index.d.ts.map +1 -0
  50. package/dist/types/src/containers/ShortcutsHints/ShortcutsHints.d.ts +2 -0
  51. package/dist/types/src/containers/ShortcutsHints/ShortcutsHints.d.ts.map +1 -0
  52. package/dist/types/src/containers/ShortcutsHints/index.d.ts +3 -0
  53. package/dist/types/src/containers/ShortcutsHints/index.d.ts.map +1 -0
  54. package/dist/types/src/containers/ShortcutsList/ShortcutsList.d.ts +2 -0
  55. package/dist/types/src/containers/ShortcutsList/ShortcutsList.d.ts.map +1 -0
  56. package/dist/types/src/containers/ShortcutsList/index.d.ts +3 -0
  57. package/dist/types/src/containers/ShortcutsList/index.d.ts.map +1 -0
  58. package/dist/types/src/containers/index.d.ts +5 -0
  59. package/dist/types/src/containers/index.d.ts.map +1 -0
  60. package/dist/types/src/index.d.ts +1 -0
  61. package/dist/types/src/index.d.ts.map +1 -1
  62. package/dist/types/src/types/schema.d.ts +1 -1
  63. package/dist/types/tsconfig.tsbuildinfo +1 -1
  64. package/package.json +29 -28
  65. package/src/HelpPlugin.tsx +8 -7
  66. package/src/capabilities/app-graph-builder/app-graph-builder.ts +8 -8
  67. package/src/capabilities/operation-resolver/operation-resolver.ts +3 -3
  68. package/src/capabilities/react-root/react-root.tsx +3 -3
  69. package/src/capabilities/react-surface/react-surface.tsx +10 -8
  70. package/src/components/Shortcuts/ShortcutsHints.tsx +1 -1
  71. package/src/components/Shortcuts/ShortcutsList.tsx +2 -2
  72. package/src/components/Shortcuts/ShortcutsSection.tsx +1 -3
  73. package/src/components/Shortcuts/index.ts +0 -1
  74. package/src/components/Shortcuts/styles.ts +2 -2
  75. package/src/components/Tooltip/Tooltip.tsx +4 -4
  76. package/src/components/WelcomeTour/WelcomeTour.stories.tsx +6 -6
  77. package/src/components/WelcomeTour/WelcomeTour.tsx +2 -1
  78. package/src/constants.ts +7 -0
  79. package/src/{components/Shortcuts/ShortcutsDialog.tsx → containers/ShortcutsDialogContent/ShortcutsDialogContent.tsx} +2 -5
  80. package/src/containers/ShortcutsDialogContent/index.ts +7 -0
  81. package/src/containers/ShortcutsHints/ShortcutsHints.tsx +5 -0
  82. package/src/containers/ShortcutsHints/index.ts +7 -0
  83. package/src/containers/ShortcutsList/ShortcutsList.tsx +5 -0
  84. package/src/containers/ShortcutsList/index.ts +7 -0
  85. package/src/containers/index.ts +9 -0
  86. package/src/index.ts +1 -0
  87. package/src/meta.ts +1 -1
  88. package/src/types/capabilities.ts +1 -1
  89. package/src/types/schema.ts +2 -2
  90. package/dist/lib/browser/app-graph-builder-DX3VXARQ.mjs.map +0 -7
  91. package/dist/lib/browser/chunk-W5XAZM46.mjs.map +0 -7
  92. package/dist/lib/browser/react-root-SZRF6EXG.mjs.map +0 -7
  93. package/dist/lib/browser/react-surface-DWNTJBVM.mjs +0 -37
  94. package/dist/lib/browser/react-surface-DWNTJBVM.mjs.map +0 -7
  95. package/dist/types/src/components/Shortcuts/ShortcutsDialog.d.ts.map +0 -1
  96. /package/dist/lib/browser/{state-VRPLKT3F.mjs.map → state-SEPP77HO.mjs.map} +0 -0
@@ -0,0 +1,36 @@
1
+ import {
2
+ ShortcutsList
3
+ } from "./chunk-VGW5FGD7.mjs";
4
+ import "./chunk-HMLZFBYY.mjs";
5
+ import {
6
+ meta
7
+ } from "./chunk-TEXIV2IJ.mjs";
8
+
9
+ // src/containers/ShortcutsDialogContent/ShortcutsDialogContent.tsx
10
+ import React from "react";
11
+ import { Dialog, IconButton, useTranslation } from "@dxos/react-ui";
12
+ var ShortcutsDialogContent = () => {
13
+ const { t } = useTranslation(meta.id);
14
+ return /* @__PURE__ */ React.createElement(Dialog.Content, null, /* @__PURE__ */ React.createElement("div", {
15
+ role: "none",
16
+ className: "flex justify-between mb-1 pt-3 ps-2 pe-3 @md:pt-4 @md:ps-4 @md:pe-5"
17
+ }, /* @__PURE__ */ React.createElement(Dialog.Title, null, t("shortcuts dialog title")), /* @__PURE__ */ React.createElement(Dialog.Close, {
18
+ asChild: true
19
+ }, /* @__PURE__ */ React.createElement(IconButton, {
20
+ icon: "ph--x--bold",
21
+ iconOnly: true,
22
+ size: 3,
23
+ label: "Close",
24
+ variant: "ghost",
25
+ autoFocus: true
26
+ }))), /* @__PURE__ */ React.createElement("div", {
27
+ className: "flex items-center justify-center"
28
+ }, /* @__PURE__ */ React.createElement(ShortcutsList, null)));
29
+ };
30
+
31
+ // src/containers/ShortcutsDialogContent/index.ts
32
+ var ShortcutsDialogContent_default = ShortcutsDialogContent;
33
+ export {
34
+ ShortcutsDialogContent_default as default
35
+ };
36
+ //# sourceMappingURL=ShortcutsDialogContent-SFEN5YKG.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/containers/ShortcutsDialogContent/ShortcutsDialogContent.tsx", "../../../src/containers/ShortcutsDialogContent/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Dialog, IconButton, useTranslation } from '@dxos/react-ui';\n\nimport { ShortcutsList } from '../../components';\nimport { meta } from '../../meta';\n\nexport const ShortcutsDialogContent = () => {\n const { t } = useTranslation(meta.id);\n\n return (\n <Dialog.Content>\n <div role='none' className='flex justify-between mb-1 pt-3 ps-2 pe-3 @md:pt-4 @md:ps-4 @md:pe-5'>\n <Dialog.Title>{t('shortcuts dialog title')}</Dialog.Title>\n <Dialog.Close asChild>\n <IconButton icon='ph--x--bold' iconOnly size={3} label='Close' variant='ghost' autoFocus />\n </Dialog.Close>\n </div>\n\n <div className='flex items-center justify-center'>\n <ShortcutsList />\n </div>\n </Dialog.Content>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { ShortcutsDialogContent } from './ShortcutsDialogContent';\n\nexport default ShortcutsDialogContent;\n"],
5
+ "mappings": ";;;;;;;;;AAIA,OAAOA,WAAW;AAElB,SAASC,QAAQC,YAAYC,sBAAsB;AAK5C,IAAMC,yBAAyB,MAAA;AACpC,QAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AAEpC,SACE,sBAAA,cAACC,OAAOC,SAAO,MACb,sBAAA,cAACC,OAAAA;IAAIC,MAAK;IAAOC,WAAU;KACzB,sBAAA,cAACJ,OAAOK,OAAK,MAAET,EAAE,wBAAA,CAAA,GACjB,sBAAA,cAACI,OAAOM,OAAK;IAACC,SAAAA;KACZ,sBAAA,cAACC,YAAAA;IAAWC,MAAK;IAAcC,UAAAA;IAASC,MAAM;IAAGC,OAAM;IAAQC,SAAQ;IAAQC,WAAAA;QAInF,sBAAA,cAACZ,OAAAA;IAAIE,WAAU;KACb,sBAAA,cAACW,eAAAA,IAAAA,CAAAA,CAAAA;AAIT;;;ACtBA,IAAA,iCAAeC;",
6
+ "names": ["React", "Dialog", "IconButton", "useTranslation", "ShortcutsDialogContent", "t", "useTranslation", "meta", "id", "Dialog", "Content", "div", "role", "className", "Title", "Close", "asChild", "IconButton", "icon", "iconOnly", "size", "label", "variant", "autoFocus", "ShortcutsList", "ShortcutsDialogContent"]
7
+ }
@@ -0,0 +1,12 @@
1
+ import {
2
+ ShortcutsHints
3
+ } from "./chunk-VGW5FGD7.mjs";
4
+ import "./chunk-HMLZFBYY.mjs";
5
+ import "./chunk-TEXIV2IJ.mjs";
6
+
7
+ // src/containers/ShortcutsHints/index.ts
8
+ var ShortcutsHints_default = ShortcutsHints;
9
+ export {
10
+ ShortcutsHints_default as default
11
+ };
12
+ //# sourceMappingURL=ShortcutsHints-SUH2FE3T.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/containers/ShortcutsHints/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { ShortcutsHints } from './ShortcutsHints';\n\nexport default ShortcutsHints;\n"],
5
+ "mappings": ";;;;;;;AAMA,IAAA,yBAAeA;",
6
+ "names": ["ShortcutsHints"]
7
+ }
@@ -0,0 +1,12 @@
1
+ import {
2
+ ShortcutsList
3
+ } from "./chunk-VGW5FGD7.mjs";
4
+ import "./chunk-HMLZFBYY.mjs";
5
+ import "./chunk-TEXIV2IJ.mjs";
6
+
7
+ // src/containers/ShortcutsList/index.ts
8
+ var ShortcutsList_default = ShortcutsList;
9
+ export {
10
+ ShortcutsList_default as default
11
+ };
12
+ //# sourceMappingURL=ShortcutsList-4YPEJM33.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/containers/ShortcutsList/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { ShortcutsList } from './ShortcutsList';\n\nexport default ShortcutsList;\n"],
5
+ "mappings": ";;;;;;;AAMA,IAAA,wBAAeA;",
6
+ "names": ["ShortcutsList"]
7
+ }
@@ -1,18 +1,19 @@
1
1
  import {
2
2
  SHORTCUTS_DIALOG
3
- } from "./chunk-W5XAZM46.mjs";
3
+ } from "./chunk-P34WCEMS.mjs";
4
4
  import {
5
5
  HelpCapabilities,
6
6
  HelpOperation
7
- } from "./chunk-TS66J4C6.mjs";
7
+ } from "./chunk-HMLZFBYY.mjs";
8
8
  import {
9
9
  meta
10
- } from "./chunk-IM2QVQOH.mjs";
10
+ } from "./chunk-TEXIV2IJ.mjs";
11
11
 
12
12
  // src/capabilities/app-graph-builder/app-graph-builder.ts
13
13
  import * as Effect from "effect/Effect";
14
- import { Capability, Common } from "@dxos/app-framework";
14
+ import { Capabilities, Capability } from "@dxos/app-framework";
15
15
  import { GraphBuilder, NodeMatcher } from "@dxos/app-graph";
16
+ import { AppCapabilities, LayoutOperation } from "@dxos/app-toolkit";
16
17
  import { Operation } from "@dxos/operation";
17
18
  var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function* () {
18
19
  const extensions = yield* GraphBuilder.createExtension({
@@ -22,7 +23,7 @@ var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function
22
23
  {
23
24
  id: HelpOperation.Start.meta.key,
24
25
  data: Effect.fnUntraced(function* () {
25
- yield* Common.Capability.updateAtomValue(HelpCapabilities.State, (s) => ({
26
+ yield* Capabilities.updateAtomValue(HelpCapabilities.State, (s) => ({
26
27
  ...s,
27
28
  showHints: true
28
29
  }));
@@ -45,15 +46,14 @@ var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function
45
46
  }
46
47
  },
47
48
  {
48
- id: `${meta.id}/open-shortcuts`,
49
+ id: `${meta.id}.open-shortcuts`,
49
50
  data: Effect.fnUntraced(function* () {
50
- yield* Common.Capability.updateAtomValue(HelpCapabilities.State, (s) => ({
51
+ yield* Capabilities.updateAtomValue(HelpCapabilities.State, (s) => ({
51
52
  ...s,
52
53
  showHints: true
53
54
  }));
54
- yield* Operation.invoke(Common.LayoutOperation.UpdateDialog, {
55
- subject: SHORTCUTS_DIALOG,
56
- blockAlign: "center"
55
+ yield* Operation.invoke(LayoutOperation.UpdateDialog, {
56
+ subject: SHORTCUTS_DIALOG
57
57
  });
58
58
  }),
59
59
  properties: {
@@ -71,9 +71,9 @@ var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function
71
71
  }
72
72
  ])
73
73
  });
74
- return Capability.contributes(Common.Capability.AppGraphBuilder, extensions);
74
+ return Capability.contributes(AppCapabilities.AppGraphBuilder, extensions);
75
75
  }));
76
76
  export {
77
77
  app_graph_builder_default as default
78
78
  };
79
- //# sourceMappingURL=app-graph-builder-DX3VXARQ.mjs.map
79
+ //# sourceMappingURL=app-graph-builder-5RXPFQPI.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/app-graph-builder/app-graph-builder.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { GraphBuilder, NodeMatcher } from '@dxos/app-graph';\nimport { AppCapabilities, LayoutOperation } from '@dxos/app-toolkit';\nimport { Operation } from '@dxos/operation';\n\nimport { SHORTCUTS_DIALOG } from '../../constants';\nimport { meta } from '../../meta';\nimport { HelpCapabilities, HelpOperation } from '../../types';\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const extensions = yield* GraphBuilder.createExtension({\n id: meta.id,\n match: NodeMatcher.whenRoot,\n actions: () =>\n Effect.succeed([\n {\n id: HelpOperation.Start.meta.key,\n data: Effect.fnUntraced(function* () {\n yield* Capabilities.updateAtomValue(HelpCapabilities.State, (s) => ({ ...s, showHints: true }));\n yield* Operation.invoke(HelpOperation.Start);\n }),\n properties: {\n label: ['open help tour', { ns: meta.id }],\n icon: 'ph--info--regular',\n keyBinding: {\n macos: 'shift+meta+/',\n windows: 'shift+ctrl+/',\n linux: 'shift+ctrl+?',\n },\n testId: 'helpPlugin.openHelp',\n },\n },\n {\n id: `${meta.id}.open-shortcuts`,\n data: Effect.fnUntraced(function* () {\n yield* Capabilities.updateAtomValue(HelpCapabilities.State, (s) => ({ ...s, showHints: true }));\n yield* Operation.invoke(LayoutOperation.UpdateDialog, {\n subject: SHORTCUTS_DIALOG,\n });\n }),\n properties: {\n label: ['open shortcuts label', { ns: meta.id }],\n icon: 'ph--keyboard--regular',\n keyBinding: {\n macos: 'meta+ctrl+/',\n },\n },\n },\n ]),\n });\n\n return Capability.contributes(AppCapabilities.AppGraphBuilder, extensions);\n }),\n);\n"],
5
+ "mappings": ";;;;;;;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,cAAcC,kBAAkB;AACzC,SAASC,cAAcC,mBAAmB;AAC1C,SAASC,iBAAiBC,uBAAuB;AACjD,SAASC,iBAAiB;AAM1B,IAAA,4BAAeC,WAAWC,WACjBC,kBAAW,aAAA;AAChB,QAAMC,aAAa,OAAOC,aAAaC,gBAAgB;IACrDC,IAAIC,KAAKD;IACTE,OAAOC,YAAYC;IACnBC,SAAS,MACAC,eAAQ;MACb;QACEN,IAAIO,cAAcC,MAAMP,KAAKQ;QAC7BC,MAAad,kBAAW,aAAA;AACtB,iBAAOe,aAAaC,gBAAgBC,iBAAiBC,OAAO,CAACC,OAAO;YAAE,GAAGA;YAAGC,WAAW;UAAK,EAAA;AAC5F,iBAAOC,UAAUC,OAAOX,cAAcC,KAAK;QAC7C,CAAA;QACAW,YAAY;UACVC,OAAO;YAAC;YAAkB;cAAEC,IAAIpB,KAAKD;YAAG;;UACxCsB,MAAM;UACNC,YAAY;YACVC,OAAO;YACPC,SAAS;YACTC,OAAO;UACT;UACAC,QAAQ;QACV;MACF;MACA;QACE3B,IAAI,GAAGC,KAAKD,EAAE;QACdU,MAAad,kBAAW,aAAA;AACtB,iBAAOe,aAAaC,gBAAgBC,iBAAiBC,OAAO,CAACC,OAAO;YAAE,GAAGA;YAAGC,WAAW;UAAK,EAAA;AAC5F,iBAAOC,UAAUC,OAAOU,gBAAgBC,cAAc;YACpDC,SAASC;UACX,CAAA;QACF,CAAA;QACAZ,YAAY;UACVC,OAAO;YAAC;YAAwB;cAAEC,IAAIpB,KAAKD;YAAG;;UAC9CsB,MAAM;UACNC,YAAY;YACVC,OAAO;UACT;QACF;MACF;KACD;EACL,CAAA;AAEA,SAAO9B,WAAWsC,YAAYC,gBAAgBC,iBAAiBrC,UAAAA;AACjE,CAAA,CAAA;",
6
+ "names": ["Effect", "Capabilities", "Capability", "GraphBuilder", "NodeMatcher", "AppCapabilities", "LayoutOperation", "Operation", "Capability", "makeModule", "fnUntraced", "extensions", "GraphBuilder", "createExtension", "id", "meta", "match", "NodeMatcher", "whenRoot", "actions", "succeed", "HelpOperation", "Start", "key", "data", "Capabilities", "updateAtomValue", "HelpCapabilities", "State", "s", "showHints", "Operation", "invoke", "properties", "label", "ns", "icon", "keyBinding", "macos", "windows", "linux", "testId", "LayoutOperation", "UpdateDialog", "subject", "SHORTCUTS_DIALOG", "contributes", "AppCapabilities", "AppGraphBuilder"]
7
+ }
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  meta
3
- } from "./chunk-IM2QVQOH.mjs";
3
+ } from "./chunk-TEXIV2IJ.mjs";
4
4
 
5
5
  // src/types/capabilities.ts
6
6
  import * as Schema from "effect/Schema";
@@ -11,7 +11,7 @@ import { Capability } from "@dxos/app-framework";
11
11
  showHints: Schema.Boolean,
12
12
  showWelcome: Schema.Boolean
13
13
  }));
14
- HelpCapabilities2.State = Capability.make(`${meta.id}/capability/state`);
14
+ HelpCapabilities2.State = Capability.make(`${meta.id}.capability.state`);
15
15
  })(HelpCapabilities || (HelpCapabilities = {}));
16
16
  var HelpCapabilities;
17
17
 
@@ -32,11 +32,11 @@ var HelpContext = createContext({
32
32
  stop: () => {
33
33
  }
34
34
  });
35
- var HELP_OPERATION = `${meta.id}/operation`;
35
+ var HELP_OPERATION = `${meta.id}.operation`;
36
36
  (function(HelpOperation2) {
37
37
  HelpOperation2.Start = Operation.make({
38
38
  meta: {
39
- key: `${HELP_OPERATION}/start`,
39
+ key: `${HELP_OPERATION}.start`,
40
40
  name: "Start Help"
41
41
  },
42
42
  services: [
@@ -55,4 +55,4 @@ export {
55
55
  HelpContext,
56
56
  HelpOperation
57
57
  };
58
- //# sourceMappingURL=chunk-TS66J4C6.mjs.map
58
+ //# sourceMappingURL=chunk-HMLZFBYY.mjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/types/capabilities.ts", "../../../src/types/schema.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Atom } from '@effect-atom/atom-react';\nimport * as Schema from 'effect/Schema';\n\nimport { Capability } from '@dxos/app-framework';\n\nimport { meta } from '../meta';\n\nexport namespace HelpCapabilities {\n export const StateSchema = Schema.mutable(\n Schema.Struct({\n running: Schema.Boolean,\n showHints: Schema.Boolean,\n showWelcome: Schema.Boolean,\n }),\n );\n\n export type State = Schema.Schema.Type<typeof StateSchema>;\n\n export const State = Capability.make<Atom.Writable<State>>(`${meta.id}/capability/state`);\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\nimport { type Context, createContext } from 'react';\nimport { type Step as BaseStep } from 'react-joyride';\n\nimport { Capability, type CapabilityManager } from '@dxos/app-framework';\nimport { Operation } from '@dxos/operation';\n\nimport { meta } from '../meta';\n\nexport type Step = BaseStep & {\n before?: (capabilities: CapabilityManager.CapabilityManager) => void;\n};\n\nexport type HelpContextType = {\n running: boolean;\n steps: Step[];\n setSteps: (steps: Step[]) => void;\n setIndex: (index: number) => void;\n start: () => void;\n stop: () => void;\n};\n\nexport const HelpContext: Context<HelpContextType> = createContext<HelpContextType>({\n running: false,\n steps: [],\n setSteps: () => {},\n setIndex: () => {},\n start: () => {},\n stop: () => {},\n});\n\nconst HELP_OPERATION = `${meta.id}/operation`;\n\nexport namespace HelpOperation {\n export const Start = Operation.make({\n meta: { key: `${HELP_OPERATION}/start`, name: 'Start Help' },\n services: [Capability.Service],\n schema: { input: Schema.Void, output: Schema.Void },\n });\n}\n"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Atom } from '@effect-atom/atom-react';\nimport * as Schema from 'effect/Schema';\n\nimport { Capability } from '@dxos/app-framework';\n\nimport { meta } from '../meta';\n\nexport namespace HelpCapabilities {\n export const StateSchema = Schema.mutable(\n Schema.Struct({\n running: Schema.Boolean,\n showHints: Schema.Boolean,\n showWelcome: Schema.Boolean,\n }),\n );\n\n export type State = Schema.Schema.Type<typeof StateSchema>;\n\n export const State = Capability.make<Atom.Writable<State>>(`${meta.id}.capability.state`);\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\nimport { type Context, createContext } from 'react';\nimport { type Step as BaseStep } from 'react-joyride';\n\nimport { Capability, type CapabilityManager } from '@dxos/app-framework';\nimport { Operation } from '@dxos/operation';\n\nimport { meta } from '../meta';\n\nexport type Step = BaseStep & {\n before?: (capabilities: CapabilityManager.CapabilityManager) => void;\n};\n\nexport type HelpContextType = {\n running: boolean;\n steps: Step[];\n setSteps: (steps: Step[]) => void;\n setIndex: (index: number) => void;\n start: () => void;\n stop: () => void;\n};\n\nexport const HelpContext: Context<HelpContextType> = createContext<HelpContextType>({\n running: false,\n steps: [],\n setSteps: () => {},\n setIndex: () => {},\n start: () => {},\n stop: () => {},\n});\n\nconst HELP_OPERATION = `${meta.id}.operation`;\n\nexport namespace HelpOperation {\n export const Start = Operation.make({\n meta: { key: `${HELP_OPERATION}.start`, name: 'Start Help' },\n services: [Capability.Service],\n schema: { input: Schema.Void, output: Schema.Void },\n });\n}\n"],
5
5
  "mappings": ";;;;;AAKA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;UAIVC,mBAAAA;oBACFC,cAAqBC,eACzBC,cAAO;IACZC,SAAgBC;IAChBC,WAAkBD;IAClBE,aAAoBF;EACtB,CAAA,CAAA;oBAKWG,QAAQC,WAAWC,KAA2B,GAAGC,KAAKC,EAAE,mBAAmB;AAC1F,GAZiBZ,qBAAAA,mBAAAA,CAAAA,EAAAA;;;;ACPjB,YAAYa,aAAY;AACxB,SAAuBC,qBAAqB;AAG5C,SAASC,cAAAA,mBAA0C;AACnD,SAASC,iBAAiB;AAiBnB,IAAMC,cAAwCC,cAA+B;EAClFC,SAAS;EACTC,OAAO,CAAA;EACPC,UAAU,MAAA;EAAO;EACjBC,UAAU,MAAA;EAAO;EACjBC,OAAO,MAAA;EAAO;EACdC,MAAM,MAAA;EAAO;AACf,CAAA;AAEA,IAAMC,iBAAiB,GAAGC,KAAKC,EAAE;UAEhBC,gBAAAA;iBACFC,QAAQC,UAAUC,KAAK;IAClCL,MAAM;MAAEM,KAAK,GAAGP,cAAAA;MAAwBQ,MAAM;IAAa;IAC3DC,UAAU;MAACC,YAAWC;;IACtBC,QAAQ;MAAEC,OAAcC;MAAMC,QAAeD;IAAK;EACpD,CAAA;AACF,GANiBX,kBAAAA,gBAAAA,CAAAA,EAAAA;;",
6
6
  "names": ["Schema", "Capability", "HelpCapabilities", "StateSchema", "mutable", "Struct", "running", "Boolean", "showHints", "showWelcome", "State", "Capability", "make", "meta", "id", "Schema", "createContext", "Capability", "Operation", "HelpContext", "createContext", "running", "steps", "setSteps", "setIndex", "start", "stop", "HELP_OPERATION", "meta", "id", "HelpOperation", "Start", "Operation", "make", "key", "name", "services", "Capability", "Service", "schema", "input", "Void", "output"]
7
7
  }
@@ -0,0 +1,11 @@
1
+ import {
2
+ meta
3
+ } from "./chunk-TEXIV2IJ.mjs";
4
+
5
+ // src/constants.ts
6
+ var SHORTCUTS_DIALOG = `${meta.id}.ShortcutsDialog`;
7
+
8
+ export {
9
+ SHORTCUTS_DIALOG
10
+ };
11
+ //# sourceMappingURL=chunk-P34WCEMS.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/constants.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { meta } from './meta';\n\nexport const SHORTCUTS_DIALOG = `${meta.id}.ShortcutsDialog`;\n"],
5
+ "mappings": ";;;;;AAMO,IAAMA,mBAAmB,GAAGC,KAAKC,EAAE;",
6
+ "names": ["SHORTCUTS_DIALOG", "meta", "id"]
7
+ }
@@ -1,7 +1,7 @@
1
1
  // src/meta.ts
2
2
  import { trim } from "@dxos/util";
3
3
  var meta = {
4
- id: "dxos.org/plugin/help",
4
+ id: "org.dxos.plugin.help",
5
5
  name: "Help",
6
6
  description: trim`
7
7
  Built-in help system with documentation, tutorials, and contextual assistance.
@@ -13,4 +13,4 @@ var meta = {
13
13
  export {
14
14
  meta
15
15
  };
16
- //# sourceMappingURL=chunk-IM2QVQOH.mjs.map
16
+ //# sourceMappingURL=chunk-TEXIV2IJ.mjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/meta.ts"],
4
- "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Plugin } from '@dxos/app-framework';\nimport { trim } from '@dxos/util';\n\nexport const meta: Plugin.Meta = {\n id: 'dxos.org/plugin/help',\n name: 'Help',\n description: trim`\n Built-in help system with documentation, tutorials, and contextual assistance.\n Access keyboard shortcuts, feature guides, and support resources.\n `,\n icon: 'ph--info--regular',\n};\n"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Plugin } from '@dxos/app-framework';\nimport { trim } from '@dxos/util';\n\nexport const meta: Plugin.Meta = {\n id: 'org.dxos.plugin.help',\n name: 'Help',\n description: trim`\n Built-in help system with documentation, tutorials, and contextual assistance.\n Access keyboard shortcuts, feature guides, and support resources.\n `,\n icon: 'ph--info--regular',\n};\n"],
5
5
  "mappings": ";AAKA,SAASA,YAAY;AAEd,IAAMC,OAAoB;EAC/BC,IAAI;EACJC,MAAM;EACNC,aAAaC;;;;EAIbC,MAAM;AACR;",
6
6
  "names": ["trim", "meta", "id", "name", "description", "trim", "icon"]
7
7
  }
@@ -1,9 +1,9 @@
1
1
  import {
2
2
  HelpContext
3
- } from "./chunk-TS66J4C6.mjs";
3
+ } from "./chunk-HMLZFBYY.mjs";
4
4
  import {
5
5
  meta
6
- } from "./chunk-IM2QVQOH.mjs";
6
+ } from "./chunk-TEXIV2IJ.mjs";
7
7
 
8
8
  // src/components/Shortcuts/Key.tsx
9
9
  import React from "react";
@@ -11,7 +11,7 @@ import { keySymbols } from "@dxos/keyboard";
11
11
 
12
12
  // src/components/Shortcuts/styles.ts
13
13
  import { mx } from "@dxos/ui-theme";
14
- var shortcutKey = mx("inline-flex min-is-[24px] bs-[24px] pli-0.5 justify-center items-center text-xs", "rounded bg-neutral-100 dark:bg-neutral-900");
14
+ var shortcutKey = mx("inline-flex min-w-[24px] h-[24px] px-0.5 justify-center items-center text-xs", "rounded-sm bg-neutral-100 dark:bg-neutral-900");
15
15
 
16
16
  // src/components/Shortcuts/Key.tsx
17
17
  var Key = ({ binding }) => {
@@ -26,68 +26,21 @@ var Key = ({ binding }) => {
26
26
  }, c)));
27
27
  };
28
28
 
29
- // src/components/Shortcuts/ShortcutsList.tsx
30
- import React2, { Fragment } from "react";
31
- import { Keyboard } from "@dxos/keyboard";
32
- import { toLocalizedString, useTranslation } from "@dxos/react-ui";
33
- import { mx as mx2 } from "@dxos/ui-theme";
34
- var ShortcutsList = () => {
35
- const { t } = useTranslation(meta.id);
36
- const bindings = Keyboard.singleton.getBindings();
37
- bindings.sort((a, b) => {
38
- return toLocalizedString(a.data, t)?.toLowerCase().localeCompare(toLocalizedString(b.data, t)?.toLowerCase());
39
- });
40
- return /* @__PURE__ */ React2.createElement("dl", {
41
- className: mx2("is-fit grid grid-cols-[min-content_minmax(12rem,1fr)] gap-2 mlb-4 text-subdued select-none")
42
- }, bindings.map((binding, i) => /* @__PURE__ */ React2.createElement(Fragment, {
43
- key: i
44
- }, /* @__PURE__ */ React2.createElement(Key, {
45
- binding: binding.shortcut
46
- }), /* @__PURE__ */ React2.createElement("span", {
47
- role: "definition",
48
- className: "mis-4",
49
- "aria-labelledby": binding.shortcut
50
- }, toLocalizedString(binding.data, t)))));
51
- };
52
-
53
- // src/components/Shortcuts/ShortcutsDialog.tsx
54
- import React3 from "react";
55
- import { Dialog, IconButton, useTranslation as useTranslation2 } from "@dxos/react-ui";
56
- var SHORTCUTS_DIALOG = `${meta.id}/ShortcutsDialog`;
57
- var ShortcutsDialogContent = () => {
58
- const { t } = useTranslation2(meta.id);
59
- return /* @__PURE__ */ React3.createElement(Dialog.Content, null, /* @__PURE__ */ React3.createElement("div", {
60
- role: "none",
61
- className: "flex justify-between mbe-1 pbs-3 pis-2 pie-3 @md:pbs-4 @md:pis-4 @md:pie-5"
62
- }, /* @__PURE__ */ React3.createElement(Dialog.Title, null, t("shortcuts dialog title")), /* @__PURE__ */ React3.createElement(Dialog.Close, {
63
- asChild: true
64
- }, /* @__PURE__ */ React3.createElement(IconButton, {
65
- icon: "ph--x--bold",
66
- iconOnly: true,
67
- size: 3,
68
- label: "Close",
69
- variant: "ghost",
70
- autoFocus: true
71
- }))), /* @__PURE__ */ React3.createElement("div", {
72
- className: "flex items-center justify-center"
73
- }, /* @__PURE__ */ React3.createElement(ShortcutsList, null)));
74
- };
75
-
76
29
  // src/components/Shortcuts/ShortcutsHints.tsx
77
- import React4 from "react";
78
- import { Keyboard as Keyboard2 } from "@dxos/keyboard";
79
- import { IconButton as IconButton2, toLocalizedString as toLocalizedString2, useTranslation as useTranslation3 } from "@dxos/react-ui";
30
+ import React2 from "react";
31
+ import { Keyboard } from "@dxos/keyboard";
32
+ import { IconButton, toLocalizedString, useTranslation } from "@dxos/react-ui";
80
33
  import { osTranslations } from "@dxos/ui-theme";
81
34
  var Shortcut = ({ binding }) => {
82
- const { t } = useTranslation3(osTranslations);
83
- return /* @__PURE__ */ React4.createElement("div", {
35
+ const { t } = useTranslation(osTranslations);
36
+ return /* @__PURE__ */ React2.createElement("div", {
84
37
  role: "none",
85
38
  className: "flex items-center gap-2 whitespace-nowrap"
86
- }, /* @__PURE__ */ React4.createElement(Key, {
39
+ }, /* @__PURE__ */ React2.createElement(Key, {
87
40
  binding: binding.shortcut
88
- }), /* @__PURE__ */ React4.createElement("span", {
41
+ }), /* @__PURE__ */ React2.createElement("span", {
89
42
  className: "text-sm"
90
- }, toLocalizedString2(binding.data, t)));
43
+ }, toLocalizedString(binding.data, t)));
91
44
  };
92
45
  var ShortcutsHints = ({ onClose }) => {
93
46
  const defaults = [
@@ -95,15 +48,15 @@ var ShortcutsHints = ({ onClose }) => {
95
48
  "meta+/",
96
49
  "meta+,"
97
50
  ];
98
- const bindings = Keyboard2.singleton.getBindings();
51
+ const bindings = Keyboard.singleton.getBindings();
99
52
  const hints = bindings.filter((binding) => defaults.includes(binding.shortcut));
100
- return /* @__PURE__ */ React4.createElement("div", {
53
+ return /* @__PURE__ */ React2.createElement("div", {
101
54
  role: "none",
102
- className: "flex overflow-hidden pli-2 gap-4"
103
- }, hints.map((binding) => /* @__PURE__ */ React4.createElement(Shortcut, {
55
+ className: "flex overflow-hidden px-2 gap-4"
56
+ }, hints.map((binding) => /* @__PURE__ */ React2.createElement(Shortcut, {
104
57
  key: binding.shortcut,
105
58
  binding
106
- })), onClose && /* @__PURE__ */ React4.createElement(IconButton2, {
59
+ })), onClose && /* @__PURE__ */ React2.createElement(IconButton, {
107
60
  icon: "ph--x--regular",
108
61
  size: 4,
109
62
  label: "Close",
@@ -115,19 +68,42 @@ var ShortcutsHints = ({ onClose }) => {
115
68
  }));
116
69
  };
117
70
 
71
+ // src/components/Shortcuts/ShortcutsList.tsx
72
+ import React3, { Fragment } from "react";
73
+ import { Keyboard as Keyboard2 } from "@dxos/keyboard";
74
+ import { toLocalizedString as toLocalizedString2, useTranslation as useTranslation2 } from "@dxos/react-ui";
75
+ import { mx as mx2 } from "@dxos/ui-theme";
76
+ var ShortcutsList = () => {
77
+ const { t } = useTranslation2(meta.id);
78
+ const bindings = Keyboard2.singleton.getBindings();
79
+ bindings.sort((a, b) => {
80
+ return toLocalizedString2(a.data, t)?.toLowerCase().localeCompare(toLocalizedString2(b.data, t)?.toLowerCase());
81
+ });
82
+ return /* @__PURE__ */ React3.createElement("dl", {
83
+ className: mx2("w-fit grid grid-cols-[min-content_minmax(12rem,1fr)] gap-2 my-4 text-subdued select-none")
84
+ }, bindings.map((binding, i) => /* @__PURE__ */ React3.createElement(Fragment, {
85
+ key: i
86
+ }, /* @__PURE__ */ React3.createElement(Key, {
87
+ binding: binding.shortcut
88
+ }), /* @__PURE__ */ React3.createElement("span", {
89
+ role: "definition",
90
+ className: "ms-4",
91
+ "aria-labelledby": binding.shortcut
92
+ }, toLocalizedString2(binding.data, t)))));
93
+ };
94
+
118
95
  // src/components/Shortcuts/ShortcutsSection.tsx
119
- import React5 from "react";
120
- import { descriptionText } from "@dxos/ui-theme";
96
+ import React4 from "react";
121
97
  var ShortcutsSection = () => {
122
- return /* @__PURE__ */ React5.createElement("section", {
123
- className: descriptionText
124
- }, /* @__PURE__ */ React5.createElement(ShortcutsList, null));
98
+ return /* @__PURE__ */ React4.createElement("section", {
99
+ className: "text-description"
100
+ }, /* @__PURE__ */ React4.createElement(ShortcutsList, null));
125
101
  };
126
102
 
127
103
  // src/components/Tooltip/Tooltip.tsx
128
104
  import { useArrowNavigationGroup, useFocusableGroup } from "@fluentui/react-tabster";
129
- import React6, { forwardRef } from "react";
130
- import { Button, Icon, IconButton as IconButton3 } from "@dxos/react-ui";
105
+ import React5, { forwardRef } from "react";
106
+ import { Button, Icon, IconButton as IconButton2 } from "@dxos/react-ui";
131
107
  var floaterProps = {
132
108
  styles: {
133
109
  // Arrow color is set by joyride.
@@ -148,18 +124,18 @@ var Tooltip = /* @__PURE__ */ forwardRef(({ step: { title, content }, index, siz
148
124
  const focusableGroupAttrs = useFocusableGroup({
149
125
  tabBehavior: "limited-trap-focus"
150
126
  });
151
- return /* @__PURE__ */ React6.createElement("div", {
152
- className: "flex flex-col is-[15rem] min-bs-[10rem] overflow-hidden rounded-md shadow-xl bg-accentSurface text-accentSurfaceText",
127
+ return /* @__PURE__ */ React5.createElement("div", {
128
+ className: "flex flex-col w-[15rem] min-h-[10rem] overflow-hidden rounded-md shadow-xl bg-accent-surface text-accent-surface-text",
153
129
  role: "tooltip",
154
130
  "data-testid": "helpPlugin.tooltip",
155
131
  "data-step": index + 1,
156
132
  ...focusableGroupAttrs,
157
133
  ref: forwardedRef
158
- }, /* @__PURE__ */ React6.createElement("div", {
134
+ }, /* @__PURE__ */ React5.createElement("div", {
159
135
  className: "flex p-2"
160
- }, /* @__PURE__ */ React6.createElement("h2", {
161
- className: "grow pli-2 plb-1 text-lg font-medium text-accentSurfaceText"
162
- }, title), /* @__PURE__ */ React6.createElement(IconButton3, {
136
+ }, /* @__PURE__ */ React5.createElement("h2", {
137
+ className: "grow px-2 py-1 text-lg font-medium text-accent-surface-text"
138
+ }, title), /* @__PURE__ */ React5.createElement(IconButton2, {
163
139
  density: "fine",
164
140
  icon: "ph--x--bold",
165
141
  iconOnly: true,
@@ -168,12 +144,12 @@ var Tooltip = /* @__PURE__ */ forwardRef(({ step: { title, content }, index, siz
168
144
  size: 4,
169
145
  variant: "primary",
170
146
  "data-testid": "helpPlugin.tooltip.close"
171
- })), /* @__PURE__ */ React6.createElement("div", {
172
- className: "flex grow pli-4 mlb-2"
173
- }, content), /* @__PURE__ */ React6.createElement("div", {
147
+ })), /* @__PURE__ */ React5.createElement("div", {
148
+ className: "flex grow px-4 my-2"
149
+ }, content), /* @__PURE__ */ React5.createElement("div", {
174
150
  className: "flex p-2 items-center justify-between",
175
151
  ...arrowNavigationAttrs
176
- }, /* @__PURE__ */ React6.createElement(IconButton3, {
152
+ }, /* @__PURE__ */ React5.createElement(IconButton2, {
177
153
  classNames: [
178
154
  !(index > 0 && backProps) && "invisible"
179
155
  ],
@@ -183,24 +159,24 @@ var Tooltip = /* @__PURE__ */ forwardRef(({ step: { title, content }, index, siz
183
159
  onClick: backProps.onClick,
184
160
  variant: "primary",
185
161
  "data-testid": "helpPlugin.tooltip.back"
186
- }), /* @__PURE__ */ React6.createElement("div", {
162
+ }), /* @__PURE__ */ React5.createElement("div", {
187
163
  className: "flex grow gap-2 justify-center"
188
- }, /* @__PURE__ */ React6.createElement("div", {
164
+ }, /* @__PURE__ */ React5.createElement("div", {
189
165
  className: "flex"
190
166
  }, Array.from({
191
167
  length: size
192
- }).map((_, i) => /* @__PURE__ */ React6.createElement(Icon, {
168
+ }).map((_, i) => /* @__PURE__ */ React5.createElement(Icon, {
193
169
  key: i,
194
170
  icon: index === i ? "ph--circle--fill" : "ph--circle--regular",
195
171
  size: 2,
196
- classNames: "mli-1 cursor-pointer"
197
- })))), isLastStep ? /* @__PURE__ */ React6.createElement(Button, {
172
+ classNames: "mx-1 cursor-pointer"
173
+ })))), isLastStep ? /* @__PURE__ */ React5.createElement(Button, {
198
174
  variant: "primary",
199
175
  onClick: closeProps.onClick,
200
176
  title: closeProps["aria-label"],
201
177
  autoFocus: true,
202
178
  "data-testid": "helpPlugin.tooltip.finish"
203
- }, "Done") : /* @__PURE__ */ React6.createElement(IconButton3, {
179
+ }, "Done") : /* @__PURE__ */ React5.createElement(IconButton2, {
204
180
  autoFocus: true,
205
181
  icon: "ph--caret-right--regular",
206
182
  iconOnly: true,
@@ -213,9 +189,10 @@ var Tooltip = /* @__PURE__ */ forwardRef(({ step: { title, content }, index, siz
213
189
  });
214
190
 
215
191
  // src/components/WelcomeTour/WelcomeTour.tsx
216
- import React7, { useState } from "react";
192
+ import React6, { useState } from "react";
217
193
  import Joyride, { ACTIONS, EVENTS } from "react-joyride";
218
- import { useLayout, usePluginManager } from "@dxos/app-framework/react";
194
+ import { usePluginManager } from "@dxos/app-framework/ui";
195
+ import { useLayout } from "@dxos/app-toolkit/ui";
219
196
  import { useAsyncEffect } from "@dxos/react-ui";
220
197
  var addStepClass = (target) => {
221
198
  const element = typeof target === "string" ? document.querySelector(target) : target;
@@ -324,7 +301,7 @@ var WelcomeTour = ({ steps: initialSteps, running: runningProp, onRunningChanged
324
301
  break;
325
302
  }
326
303
  };
327
- return /* @__PURE__ */ React7.createElement(HelpContext.Provider, {
304
+ return /* @__PURE__ */ React6.createElement(HelpContext.Provider, {
328
305
  value: {
329
306
  running: running && !paused,
330
307
  steps,
@@ -333,9 +310,9 @@ var WelcomeTour = ({ steps: initialSteps, running: runningProp, onRunningChanged
333
310
  start: () => setRunningChanged(true),
334
311
  stop: () => setRunningChanged(false)
335
312
  }
336
- }, /* @__PURE__ */ React7.createElement("style", null, `.joyride-target {
313
+ }, /* @__PURE__ */ React6.createElement("style", null, `.joyride-target {
337
314
  --controls-opacity: 1;
338
- }`), /* @__PURE__ */ React7.createElement(Joyride, {
315
+ }`), /* @__PURE__ */ React6.createElement(Joyride, {
339
316
  continuous: true,
340
317
  steps,
341
318
  stepIndex,
@@ -348,13 +325,11 @@ var WelcomeTour = ({ steps: initialSteps, running: runningProp, onRunningChanged
348
325
 
349
326
  export {
350
327
  Key,
351
- ShortcutsList,
352
- SHORTCUTS_DIALOG,
353
- ShortcutsDialogContent,
354
328
  ShortcutsHints,
329
+ ShortcutsList,
355
330
  ShortcutsSection,
356
331
  floaterProps,
357
332
  Tooltip,
358
333
  WelcomeTour
359
334
  };
360
- //# sourceMappingURL=chunk-W5XAZM46.mjs.map
335
+ //# sourceMappingURL=chunk-VGW5FGD7.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/Shortcuts/Key.tsx", "../../../src/components/Shortcuts/styles.ts", "../../../src/components/Shortcuts/ShortcutsHints.tsx", "../../../src/components/Shortcuts/ShortcutsList.tsx", "../../../src/components/Shortcuts/ShortcutsSection.tsx", "../../../src/components/Tooltip/Tooltip.tsx", "../../../src/components/WelcomeTour/WelcomeTour.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { keySymbols } from '@dxos/keyboard';\n\nimport { shortcutKey } from './styles';\n\nexport const Key = ({ binding }: { binding: string }) => {\n return (\n <span role='term' className='inline-flex gap-1' aria-label={binding} id={binding}>\n {keySymbols(binding).map((c, i) => (\n <span key={i} className={shortcutKey}>\n {c}\n </span>\n ))}\n </span>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { mx } from '@dxos/ui-theme';\n\nexport const shortcutKey = mx(\n 'inline-flex min-w-[24px] h-[24px] px-0.5 justify-center items-center text-xs',\n 'rounded-sm bg-neutral-100 dark:bg-neutral-900',\n);\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { type KeyBinding, Keyboard } from '@dxos/keyboard';\nimport { IconButton, toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { osTranslations } from '@dxos/ui-theme';\n\nimport { Key } from './Key';\n\nconst Shortcut = ({ binding }: { binding: KeyBinding }) => {\n const { t } = useTranslation(osTranslations);\n return (\n <div role='none' className='flex items-center gap-2 whitespace-nowrap'>\n <Key binding={binding.shortcut} />\n <span className='text-sm'>{toLocalizedString(binding.data, t)}</span>\n </div>\n );\n};\n\nexport const ShortcutsHints = ({ onClose }: { onClose?: () => void }) => {\n // TODO(burdon): Display by context/weight/cycle.\n const defaults = ['meta+k', 'meta+/', 'meta+,'];\n const bindings = Keyboard.singleton.getBindings();\n const hints = bindings.filter((binding) => defaults.includes(binding.shortcut));\n\n return (\n <div role='none' className='flex overflow-hidden px-2 gap-4'>\n {hints.map((binding) => (\n <Shortcut key={binding.shortcut} binding={binding} />\n ))}\n {onClose && (\n <IconButton\n icon='ph--x--regular'\n size={4}\n label='Close'\n iconOnly\n noTooltip\n variant='ghost'\n classNames='p-0 cursor-pointer'\n onClick={onClose}\n />\n )}\n </div>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { Fragment } from 'react';\n\nimport { Keyboard } from '@dxos/keyboard';\nimport { toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { mx } from '@dxos/ui-theme';\n\nimport { meta } from '../../meta';\n\nimport { Key } from './Key';\n\nexport const ShortcutsList = () => {\n const { t } = useTranslation(meta.id);\n const bindings = Keyboard.singleton.getBindings();\n\n // TODO(burdon): Get shortcuts from TextEditor.\n bindings.sort((a, b) => {\n return toLocalizedString(a.data, t)?.toLowerCase().localeCompare(toLocalizedString(b.data, t)?.toLowerCase());\n });\n\n return (\n <dl className={mx('w-fit grid grid-cols-[min-content_minmax(12rem,1fr)] gap-2 my-4 text-subdued select-none')}>\n {bindings.map((binding, i) => (\n <Fragment key={i}>\n <Key binding={binding.shortcut} />\n <span role='definition' className='ms-4' aria-labelledby={binding.shortcut}>\n {toLocalizedString(binding.data, t)}\n </span>\n </Fragment>\n ))}\n </dl>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { ShortcutsList } from './ShortcutsList';\n\nexport const ShortcutsSection = () => {\n return (\n <section className='text-description'>\n <ShortcutsList />\n </section>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { useArrowNavigationGroup, useFocusableGroup } from '@fluentui/react-tabster';\nimport React, { forwardRef } from 'react';\n// TODO(thure): This needed to be imported in the package.json specifically to pacify TS2742. See if this is resolved with typescript@5.5.x.\n// eslint-disable-next-line unused-imports/no-unused-imports\nimport _floater from 'react-floater';\nimport { type Props, type TooltipRenderProps } from 'react-joyride';\n// TODO(thure): This needed to be imported in the package.json specifically to pacify TS2742. See if this is resolved with typescript@5.5.x.\n// eslint-disable-next-line unused-imports/no-unused-imports\nimport _typefest from 'type-fest';\n\nimport { Button, Icon, IconButton } from '@dxos/react-ui';\n\n// https://docs.react-joyride.com/styling\n// https://github.com/gilbarbara/react-floater\nexport const floaterProps: Props['floaterProps'] = {\n styles: {\n // Arrow color is set by joyride.\n arrow: {\n length: 8,\n spread: 16,\n },\n floater: {\n // TODO(burdon): Get tokens from theme.\n filter: 'drop-shadow(0 0 0.75rem rgba(0, 0, 0, 0.2))',\n },\n },\n};\n\n// TODO(burdon): Add info link to docs.\nexport const Tooltip = forwardRef<HTMLDivElement, TooltipRenderProps>(\n ({ step: { title, content }, index, size, isLastStep, backProps, closeProps, primaryProps }, forwardedRef) => {\n const arrowNavigationAttrs = useArrowNavigationGroup({ axis: 'horizontal' });\n const focusableGroupAttrs = useFocusableGroup({ tabBehavior: 'limited-trap-focus' });\n\n return (\n <div\n className='flex flex-col w-[15rem] min-h-[10rem] overflow-hidden rounded-md shadow-xl bg-accent-surface text-accent-surface-text'\n role='tooltip'\n data-testid='helpPlugin.tooltip'\n data-step={index + 1}\n {...focusableGroupAttrs}\n ref={forwardedRef}\n >\n <div className='flex p-2'>\n <h2 className='grow px-2 py-1 text-lg font-medium text-accent-surface-text'>{title}</h2>\n <IconButton\n density='fine'\n icon='ph--x--bold'\n iconOnly\n label={closeProps['aria-label']}\n onClick={closeProps.onClick}\n size={4}\n variant='primary'\n data-testid='helpPlugin.tooltip.close'\n />\n </div>\n <div className='flex grow px-4 my-2'>{content}</div>\n <div className='flex p-2 items-center justify-between' {...arrowNavigationAttrs}>\n {\n <IconButton\n classNames={[!(index > 0 && backProps) && 'invisible']}\n icon='ph--caret-left--regular'\n iconOnly\n label={backProps['aria-label']}\n onClick={backProps.onClick}\n variant='primary'\n data-testid='helpPlugin.tooltip.back'\n />\n }\n <div className='flex grow gap-2 justify-center'>\n <div className='flex'>\n {Array.from({ length: size }).map((_, i) => (\n <Icon\n key={i}\n icon={index === i ? 'ph--circle--fill' : 'ph--circle--regular'}\n size={2}\n classNames='mx-1 cursor-pointer'\n />\n ))}\n </div>\n </div>\n {isLastStep ? (\n <Button\n variant='primary'\n onClick={closeProps.onClick}\n title={closeProps['aria-label']}\n autoFocus\n data-testid='helpPlugin.tooltip.finish'\n >\n Done\n </Button>\n ) : (\n <IconButton\n autoFocus\n icon='ph--caret-right--regular'\n iconOnly\n label={primaryProps['aria-label']}\n onClick={primaryProps.onClick}\n size={6}\n variant='primary'\n data-testid='helpPlugin.tooltip.next'\n />\n )}\n </div>\n </div>\n );\n },\n);\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { useState } from 'react';\nimport Joyride, { ACTIONS, EVENTS } from 'react-joyride';\n\nimport { usePluginManager } from '@dxos/app-framework/ui';\nimport { useLayout } from '@dxos/app-toolkit/ui';\nimport { useAsyncEffect } from '@dxos/react-ui';\n\nimport { HelpContext, type Step } from '../../types';\nimport { Tooltip, floaterProps } from '../Tooltip';\n\nconst addStepClass = (target: string | HTMLElement) => {\n const element = typeof target === 'string' ? document.querySelector(target) : target;\n if (element) {\n element.classList.add('joyride-target');\n }\n};\n\nconst removeTargetClass = (target: string | HTMLElement) => {\n const element = typeof target === 'string' ? document.querySelector(target) : target;\n if (element) {\n element.classList.remove('joyride-target');\n }\n};\n\nconst getTarget = (step: Step) => {\n return typeof step.target === 'string' ? document.querySelector(step.target) : step.target;\n};\n\n/**\n * Wait for the target element to be in the document.\n */\nconst waitForTarget = async (step: Step) => {\n if (typeof step.target === 'string') {\n const target = step.target;\n const element = document.querySelector(target);\n if (element) {\n return;\n }\n\n await new Promise<void>((resolve) => {\n const observer = new MutationObserver((mutations) => {\n mutations.forEach((mutation) => {\n if (mutation.addedNodes.length > 0) {\n const element = document.querySelector(target);\n if (element) {\n observer.disconnect();\n resolve();\n }\n }\n });\n });\n\n observer.observe(document.body, { childList: true, subtree: true });\n });\n }\n};\n\nexport type WelcomeTourProps = {\n steps: Step[];\n running?: boolean;\n onRunningChanged?: (state: boolean) => any;\n};\n\nexport const WelcomeTour = ({ steps: initialSteps, running: runningProp, onRunningChanged }: WelcomeTourProps) => {\n const manager = usePluginManager();\n const layout = useLayout();\n const [running, setRunning] = useState(!!runningProp && !!getTarget(initialSteps[0]));\n const [stepIndex, _setStepIndex] = useState(0);\n const [steps, setSteps] = useState(initialSteps);\n\n const paused = layout.dialogOpen;\n\n const setStepIndex = (index: number) => {\n if (runningProp) {\n const step = steps[index];\n step?.before?.(manager.capabilities);\n }\n _setStepIndex(index);\n };\n\n const setRunningChanged = (state: boolean) => {\n if (typeof runningProp !== 'undefined') {\n onRunningChanged?.(state);\n } else {\n if (state) {\n setStepIndex(0);\n setRunning(true);\n } else {\n setRunning(false);\n }\n }\n };\n\n useAsyncEffect(async () => {\n if (runningProp) {\n // This handles the case when the target is not yet in the document.\n // If the target is not in the document, when the joyride is turned on, it will not show the tooltip.\n await waitForTarget(steps[stepIndex]);\n setStepIndex(0);\n setRunning(true);\n } else if (typeof runningProp !== 'undefined') {\n setRunning(false);\n }\n }, [runningProp]);\n\n // https://docs.react-joyride.com/callback\n const callback: Joyride['callback'] = async (options) => {\n const { type, action, index, size } = options;\n switch (type) {\n case EVENTS.STEP_BEFORE:\n addStepClass(options.step.target);\n break;\n case EVENTS.TOUR_END:\n break;\n case EVENTS.STEP_AFTER:\n removeTargetClass(options.step.target);\n switch (action) {\n case ACTIONS.NEXT:\n if (index < size - 1) {\n setStepIndex(index + 1);\n }\n break;\n case ACTIONS.PREV:\n if (index > 0) {\n setStepIndex(index - 1);\n }\n break;\n case ACTIONS.CLOSE:\n setRunningChanged(false);\n setStepIndex(0);\n break;\n }\n break;\n }\n };\n\n return (\n <HelpContext.Provider\n value={{\n running: running && !paused,\n steps,\n setSteps,\n setIndex: setStepIndex,\n start: () => setRunningChanged(true),\n stop: () => setRunningChanged(false),\n }}\n >\n <style>\n {`.joyride-target {\n --controls-opacity: 1;\n }`}\n </style>\n <Joyride\n continuous={true}\n steps={steps}\n stepIndex={stepIndex}\n run={running && !paused}\n callback={callback}\n floaterProps={floaterProps}\n tooltipComponent={Tooltip}\n />\n </HelpContext.Provider>\n );\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "keySymbols", "mx", "shortcutKey", "mx", "Key", "binding", "span", "role", "className", "aria-label", "id", "keySymbols", "map", "c", "i", "key", "shortcutKey", "React", "Keyboard", "IconButton", "toLocalizedString", "useTranslation", "osTranslations", "Shortcut", "binding", "t", "useTranslation", "osTranslations", "React", "div", "role", "className", "Key", "shortcut", "span", "toLocalizedString", "data", "ShortcutsHints", "onClose", "defaults", "bindings", "Keyboard", "singleton", "getBindings", "hints", "filter", "includes", "map", "key", "IconButton", "icon", "size", "label", "iconOnly", "noTooltip", "variant", "classNames", "onClick", "React", "Fragment", "Keyboard", "toLocalizedString", "useTranslation", "mx", "ShortcutsList", "t", "useTranslation", "meta", "id", "bindings", "Keyboard", "singleton", "getBindings", "sort", "a", "b", "toLocalizedString", "data", "toLowerCase", "localeCompare", "React", "dl", "className", "mx", "map", "binding", "i", "Fragment", "key", "Key", "shortcut", "span", "role", "aria-labelledby", "React", "ShortcutsSection", "React", "section", "className", "ShortcutsList", "useArrowNavigationGroup", "useFocusableGroup", "React", "forwardRef", "Button", "Icon", "IconButton", "floaterProps", "styles", "arrow", "length", "spread", "floater", "filter", "Tooltip", "forwardRef", "step", "title", "content", "index", "size", "isLastStep", "backProps", "closeProps", "primaryProps", "forwardedRef", "arrowNavigationAttrs", "useArrowNavigationGroup", "axis", "focusableGroupAttrs", "useFocusableGroup", "tabBehavior", "React", "div", "className", "role", "data-testid", "data-step", "ref", "h2", "IconButton", "density", "icon", "iconOnly", "label", "onClick", "variant", "classNames", "Array", "from", "map", "_", "i", "Icon", "key", "Button", "autoFocus", "React", "useState", "Joyride", "ACTIONS", "EVENTS", "usePluginManager", "useLayout", "useAsyncEffect", "addStepClass", "target", "element", "document", "querySelector", "classList", "add", "removeTargetClass", "remove", "getTarget", "step", "waitForTarget", "Promise", "resolve", "observer", "MutationObserver", "mutations", "forEach", "mutation", "addedNodes", "length", "disconnect", "observe", "body", "childList", "subtree", "WelcomeTour", "steps", "initialSteps", "running", "runningProp", "onRunningChanged", "manager", "usePluginManager", "layout", "useLayout", "setRunning", "useState", "stepIndex", "_setStepIndex", "setSteps", "paused", "dialogOpen", "setStepIndex", "index", "before", "capabilities", "setRunningChanged", "state", "useAsyncEffect", "callback", "options", "type", "action", "size", "EVENTS", "STEP_BEFORE", "TOUR_END", "STEP_AFTER", "ACTIONS", "NEXT", "PREV", "CLOSE", "React", "HelpContext", "Provider", "value", "setIndex", "start", "stop", "style", "Joyride", "continuous", "run", "floaterProps", "tooltipComponent", "Tooltip"]
7
+ }