@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.
- package/dist/lib/browser/ShortcutsDialogContent-SFEN5YKG.mjs +36 -0
- package/dist/lib/browser/ShortcutsDialogContent-SFEN5YKG.mjs.map +7 -0
- package/dist/lib/browser/ShortcutsHints-SUH2FE3T.mjs +12 -0
- package/dist/lib/browser/ShortcutsHints-SUH2FE3T.mjs.map +7 -0
- package/dist/lib/browser/ShortcutsList-4YPEJM33.mjs +12 -0
- package/dist/lib/browser/ShortcutsList-4YPEJM33.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-builder-DX3VXARQ.mjs → app-graph-builder-5RXPFQPI.mjs} +12 -12
- package/dist/lib/browser/app-graph-builder-5RXPFQPI.mjs.map +7 -0
- package/dist/lib/browser/{chunk-TS66J4C6.mjs → chunk-HMLZFBYY.mjs} +5 -5
- package/dist/lib/browser/{chunk-TS66J4C6.mjs.map → chunk-HMLZFBYY.mjs.map} +1 -1
- package/dist/lib/browser/chunk-P34WCEMS.mjs +11 -0
- package/dist/lib/browser/chunk-P34WCEMS.mjs.map +7 -0
- package/dist/lib/browser/{chunk-IM2QVQOH.mjs → chunk-TEXIV2IJ.mjs} +2 -2
- package/dist/lib/browser/{chunk-IM2QVQOH.mjs.map → chunk-TEXIV2IJ.mjs.map} +1 -1
- package/dist/lib/browser/{chunk-W5XAZM46.mjs → chunk-VGW5FGD7.mjs} +70 -95
- package/dist/lib/browser/chunk-VGW5FGD7.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +27 -26
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/meta.mjs +1 -1
- package/dist/lib/browser/{react-root-SZRF6EXG.mjs → react-root-JBHEZA5U.mjs} +7 -7
- package/dist/lib/browser/react-root-JBHEZA5U.mjs.map +7 -0
- package/dist/lib/browser/react-surface-W5S45O6Y.mjs +42 -0
- package/dist/lib/browser/react-surface-W5S45O6Y.mjs.map +7 -0
- package/dist/lib/browser/{state-VRPLKT3F.mjs → state-SEPP77HO.mjs} +3 -3
- package/dist/lib/browser/types/index.mjs +2 -2
- package/dist/types/src/HelpPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts +1 -1
- package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +2 -2
- package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-root/index.d.ts +1 -1
- package/dist/types/src/capabilities/react-root/react-root.d.ts +1 -1
- package/dist/types/src/capabilities/react-root/react-root.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface/index.d.ts +1 -1
- package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface/react-surface.d.ts +2 -2
- package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/state/state.d.ts +1 -1
- package/dist/types/src/components/Shortcuts/ShortcutsSection.d.ts.map +1 -1
- package/dist/types/src/components/Shortcuts/index.d.ts +0 -1
- package/dist/types/src/components/Shortcuts/index.d.ts.map +1 -1
- package/dist/types/src/components/WelcomeTour/WelcomeTour.d.ts.map +1 -1
- package/dist/types/src/constants.d.ts +2 -0
- package/dist/types/src/constants.d.ts.map +1 -0
- package/dist/types/src/{components/Shortcuts/ShortcutsDialog.d.ts → containers/ShortcutsDialogContent/ShortcutsDialogContent.d.ts} +1 -2
- package/dist/types/src/containers/ShortcutsDialogContent/ShortcutsDialogContent.d.ts.map +1 -0
- package/dist/types/src/containers/ShortcutsDialogContent/index.d.ts +3 -0
- package/dist/types/src/containers/ShortcutsDialogContent/index.d.ts.map +1 -0
- package/dist/types/src/containers/ShortcutsHints/ShortcutsHints.d.ts +2 -0
- package/dist/types/src/containers/ShortcutsHints/ShortcutsHints.d.ts.map +1 -0
- package/dist/types/src/containers/ShortcutsHints/index.d.ts +3 -0
- package/dist/types/src/containers/ShortcutsHints/index.d.ts.map +1 -0
- package/dist/types/src/containers/ShortcutsList/ShortcutsList.d.ts +2 -0
- package/dist/types/src/containers/ShortcutsList/ShortcutsList.d.ts.map +1 -0
- package/dist/types/src/containers/ShortcutsList/index.d.ts +3 -0
- package/dist/types/src/containers/ShortcutsList/index.d.ts.map +1 -0
- package/dist/types/src/containers/index.d.ts +5 -0
- package/dist/types/src/containers/index.d.ts.map +1 -0
- package/dist/types/src/index.d.ts +1 -0
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +29 -28
- package/src/HelpPlugin.tsx +8 -7
- package/src/capabilities/app-graph-builder/app-graph-builder.ts +8 -8
- package/src/capabilities/operation-resolver/operation-resolver.ts +3 -3
- package/src/capabilities/react-root/react-root.tsx +3 -3
- package/src/capabilities/react-surface/react-surface.tsx +10 -8
- package/src/components/Shortcuts/ShortcutsHints.tsx +1 -1
- package/src/components/Shortcuts/ShortcutsList.tsx +2 -2
- package/src/components/Shortcuts/ShortcutsSection.tsx +1 -3
- package/src/components/Shortcuts/index.ts +0 -1
- package/src/components/Shortcuts/styles.ts +2 -2
- package/src/components/Tooltip/Tooltip.tsx +4 -4
- package/src/components/WelcomeTour/WelcomeTour.stories.tsx +6 -6
- package/src/components/WelcomeTour/WelcomeTour.tsx +2 -1
- package/src/constants.ts +7 -0
- package/src/{components/Shortcuts/ShortcutsDialog.tsx → containers/ShortcutsDialogContent/ShortcutsDialogContent.tsx} +2 -5
- package/src/containers/ShortcutsDialogContent/index.ts +7 -0
- package/src/containers/ShortcutsHints/ShortcutsHints.tsx +5 -0
- package/src/containers/ShortcutsHints/index.ts +7 -0
- package/src/containers/ShortcutsList/ShortcutsList.tsx +5 -0
- package/src/containers/ShortcutsList/index.ts +7 -0
- package/src/containers/index.ts +9 -0
- package/src/index.ts +1 -0
- package/src/meta.ts +1 -1
- package/src/types/capabilities.ts +1 -1
- package/src/types/schema.ts +2 -2
- package/dist/lib/browser/app-graph-builder-DX3VXARQ.mjs.map +0 -7
- package/dist/lib/browser/chunk-W5XAZM46.mjs.map +0 -7
- package/dist/lib/browser/react-root-SZRF6EXG.mjs.map +0 -7
- package/dist/lib/browser/react-surface-DWNTJBVM.mjs +0 -37
- package/dist/lib/browser/react-surface-DWNTJBVM.mjs.map +0 -7
- package/dist/types/src/components/Shortcuts/ShortcutsDialog.d.ts.map +0 -1
- /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-
|
|
3
|
+
} from "./chunk-P34WCEMS.mjs";
|
|
4
4
|
import {
|
|
5
5
|
HelpCapabilities,
|
|
6
6
|
HelpOperation
|
|
7
|
-
} from "./chunk-
|
|
7
|
+
} from "./chunk-HMLZFBYY.mjs";
|
|
8
8
|
import {
|
|
9
9
|
meta
|
|
10
|
-
} from "./chunk-
|
|
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 {
|
|
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*
|
|
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}
|
|
49
|
+
id: `${meta.id}.open-shortcuts`,
|
|
49
50
|
data: Effect.fnUntraced(function* () {
|
|
50
|
-
yield*
|
|
51
|
+
yield* Capabilities.updateAtomValue(HelpCapabilities.State, (s) => ({
|
|
51
52
|
...s,
|
|
52
53
|
showHints: true
|
|
53
54
|
}));
|
|
54
|
-
yield* Operation.invoke(
|
|
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(
|
|
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-
|
|
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-
|
|
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}
|
|
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}
|
|
35
|
+
var HELP_OPERATION = `${meta.id}.operation`;
|
|
36
36
|
(function(HelpOperation2) {
|
|
37
37
|
HelpOperation2.Start = Operation.make({
|
|
38
38
|
meta: {
|
|
39
|
-
key: `${HELP_OPERATION}
|
|
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-
|
|
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}
|
|
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,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.
|
|
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-
|
|
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.
|
|
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-
|
|
3
|
+
} from "./chunk-HMLZFBYY.mjs";
|
|
4
4
|
import {
|
|
5
5
|
meta
|
|
6
|
-
} from "./chunk-
|
|
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-
|
|
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
|
|
78
|
-
import { Keyboard
|
|
79
|
-
import { IconButton
|
|
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 } =
|
|
83
|
-
return /* @__PURE__ */
|
|
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__ */
|
|
39
|
+
}, /* @__PURE__ */ React2.createElement(Key, {
|
|
87
40
|
binding: binding.shortcut
|
|
88
|
-
}), /* @__PURE__ */
|
|
41
|
+
}), /* @__PURE__ */ React2.createElement("span", {
|
|
89
42
|
className: "text-sm"
|
|
90
|
-
},
|
|
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 =
|
|
51
|
+
const bindings = Keyboard.singleton.getBindings();
|
|
99
52
|
const hints = bindings.filter((binding) => defaults.includes(binding.shortcut));
|
|
100
|
-
return /* @__PURE__ */
|
|
53
|
+
return /* @__PURE__ */ React2.createElement("div", {
|
|
101
54
|
role: "none",
|
|
102
|
-
className: "flex overflow-hidden
|
|
103
|
-
}, hints.map((binding) => /* @__PURE__ */
|
|
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__ */
|
|
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
|
|
120
|
-
import { descriptionText } from "@dxos/ui-theme";
|
|
96
|
+
import React4 from "react";
|
|
121
97
|
var ShortcutsSection = () => {
|
|
122
|
-
return /* @__PURE__ */
|
|
123
|
-
className:
|
|
124
|
-
}, /* @__PURE__ */
|
|
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
|
|
130
|
-
import { Button, Icon, IconButton as
|
|
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__ */
|
|
152
|
-
className: "flex flex-col
|
|
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__ */
|
|
134
|
+
}, /* @__PURE__ */ React5.createElement("div", {
|
|
159
135
|
className: "flex p-2"
|
|
160
|
-
}, /* @__PURE__ */
|
|
161
|
-
className: "grow
|
|
162
|
-
}, title), /* @__PURE__ */
|
|
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__ */
|
|
172
|
-
className: "flex grow
|
|
173
|
-
}, content), /* @__PURE__ */
|
|
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__ */
|
|
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__ */
|
|
162
|
+
}), /* @__PURE__ */ React5.createElement("div", {
|
|
187
163
|
className: "flex grow gap-2 justify-center"
|
|
188
|
-
}, /* @__PURE__ */
|
|
164
|
+
}, /* @__PURE__ */ React5.createElement("div", {
|
|
189
165
|
className: "flex"
|
|
190
166
|
}, Array.from({
|
|
191
167
|
length: size
|
|
192
|
-
}).map((_, i) => /* @__PURE__ */
|
|
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: "
|
|
197
|
-
})))), isLastStep ? /* @__PURE__ */
|
|
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__ */
|
|
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
|
|
192
|
+
import React6, { useState } from "react";
|
|
217
193
|
import Joyride, { ACTIONS, EVENTS } from "react-joyride";
|
|
218
|
-
import {
|
|
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__ */
|
|
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__ */
|
|
313
|
+
}, /* @__PURE__ */ React6.createElement("style", null, `.joyride-target {
|
|
337
314
|
--controls-opacity: 1;
|
|
338
|
-
}`), /* @__PURE__ */
|
|
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-
|
|
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
|
+
}
|