@dxos/plugin-markdown 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/{chunk-WIPSLZ6L.mjs → MarkdownCard-R6VVXOMN.mjs} +27 -26
- package/dist/lib/browser/MarkdownCard-R6VVXOMN.mjs.map +7 -0
- package/dist/lib/browser/{chunk-KDKXFKDN.mjs → MarkdownContainer-LSOAAG6R.mjs} +48 -25
- package/dist/lib/browser/MarkdownContainer-LSOAAG6R.mjs.map +7 -0
- package/dist/lib/browser/MarkdownSettings-OD7AJSSJ.mjs +106 -0
- package/dist/lib/browser/MarkdownSettings-OD7AJSSJ.mjs.map +7 -0
- package/dist/lib/browser/{anchor-sort-WQ3TL7ZI.mjs → anchor-sort-35SV33JX.mjs} +6 -4
- package/dist/lib/browser/anchor-sort-35SV33JX.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-serializer-ULZUJKOD.mjs → app-graph-serializer-RMUNNVUY.mjs} +9 -7
- package/dist/lib/browser/app-graph-serializer-RMUNNVUY.mjs.map +7 -0
- package/dist/lib/browser/blueprint-definition-SFGTWLSY.mjs +18 -0
- package/dist/lib/browser/blueprint-definition-SFGTWLSY.mjs.map +7 -0
- package/dist/lib/browser/blueprints/index.mjs +5 -4
- package/dist/lib/browser/{chunk-LMO5UVKL.mjs → chunk-4CSOMIT4.mjs} +29 -61
- package/dist/lib/browser/chunk-4CSOMIT4.mjs.map +7 -0
- package/dist/lib/browser/chunk-646I24Q2.mjs +178 -0
- package/dist/lib/browser/chunk-646I24Q2.mjs.map +7 -0
- package/dist/lib/browser/{chunk-BX73DASG.mjs → chunk-B6S4YQWZ.mjs} +285 -206
- package/dist/lib/browser/chunk-B6S4YQWZ.mjs.map +7 -0
- package/dist/lib/browser/chunk-RYZHVXZ5.mjs +28 -0
- package/dist/lib/browser/chunk-RYZHVXZ5.mjs.map +7 -0
- package/dist/lib/browser/{chunk-CUGDX7KA.mjs → chunk-WU3CQIPM.mjs} +2 -2
- package/dist/lib/browser/{chunk-JOXYQLKH.mjs → chunk-YKXQWJX6.mjs} +9 -4
- package/dist/lib/browser/chunk-YKXQWJX6.mjs.map +7 -0
- package/dist/lib/browser/cli/index.mjs +15 -13
- package/dist/lib/browser/cli/index.mjs.map +3 -3
- package/dist/lib/browser/index.mjs +49 -48
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{operation-resolver-EGCWOQKJ.mjs → operation-resolver-MVI2ZJ7M.mjs} +6 -18
- package/dist/lib/browser/operation-resolver-MVI2ZJ7M.mjs.map +7 -0
- package/dist/lib/browser/react-surface-OJYNFGZB.mjs +117 -0
- package/dist/lib/browser/react-surface-OJYNFGZB.mjs.map +7 -0
- package/dist/lib/browser/{settings-JY5JE7MI.mjs → settings-R722LDFD.mjs} +8 -5
- package/dist/lib/browser/settings-R722LDFD.mjs.map +7 -0
- package/dist/lib/browser/{state-QE7VSJWJ.mjs → state-MRJLGZW4.mjs} +7 -5
- package/dist/lib/{node-esm/state-LXE5XIN4.mjs.map → browser/state-MRJLGZW4.mjs.map} +2 -2
- package/dist/lib/browser/types/index.mjs +2 -1
- package/dist/lib/node-esm/{chunk-RQP7G7XW.mjs → MarkdownCard-EE3Q2JPL.mjs} +27 -26
- package/dist/lib/node-esm/MarkdownCard-EE3Q2JPL.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-3JYPCC7M.mjs → MarkdownContainer-NMFVVFBR.mjs} +48 -25
- package/dist/lib/node-esm/MarkdownContainer-NMFVVFBR.mjs.map +7 -0
- package/dist/lib/node-esm/MarkdownSettings-U7GJ4OP3.mjs +107 -0
- package/dist/lib/node-esm/MarkdownSettings-U7GJ4OP3.mjs.map +7 -0
- package/dist/lib/node-esm/{anchor-sort-G7D5TAI6.mjs → anchor-sort-QCV4U222.mjs} +6 -4
- package/dist/lib/node-esm/anchor-sort-QCV4U222.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-serializer-W5YMQP7P.mjs → app-graph-serializer-I27YTNDW.mjs} +9 -7
- package/dist/lib/node-esm/app-graph-serializer-I27YTNDW.mjs.map +7 -0
- package/dist/lib/node-esm/blueprint-definition-VZEIBTAP.mjs +19 -0
- package/dist/lib/node-esm/blueprint-definition-VZEIBTAP.mjs.map +7 -0
- package/dist/lib/node-esm/blueprints/index.mjs +5 -4
- package/dist/lib/node-esm/{chunk-PRV35A7Z.mjs → chunk-2LVNBTQT.mjs} +29 -61
- package/dist/lib/node-esm/chunk-2LVNBTQT.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-CW4FZNMZ.mjs +29 -0
- package/dist/lib/node-esm/chunk-CW4FZNMZ.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-W3IIKDV5.mjs → chunk-HVAZON2M.mjs} +2 -2
- package/dist/lib/node-esm/chunk-KHTJJ45U.mjs +179 -0
- package/dist/lib/node-esm/chunk-KHTJJ45U.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-44VJC3QF.mjs → chunk-TR2NZYXO.mjs} +9 -4
- package/dist/lib/node-esm/chunk-TR2NZYXO.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-D4BCFPKK.mjs → chunk-VG2PIENM.mjs} +285 -206
- package/dist/lib/node-esm/chunk-VG2PIENM.mjs.map +7 -0
- package/dist/lib/node-esm/cli/index.mjs +15 -13
- package/dist/lib/node-esm/cli/index.mjs.map +3 -3
- package/dist/lib/node-esm/index.mjs +49 -48
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{operation-resolver-2HIS2AQZ.mjs → operation-resolver-6TK6ARJ6.mjs} +6 -18
- package/dist/lib/node-esm/operation-resolver-6TK6ARJ6.mjs.map +7 -0
- package/dist/lib/node-esm/react-surface-UVNCUX77.mjs +118 -0
- package/dist/lib/node-esm/react-surface-UVNCUX77.mjs.map +7 -0
- package/dist/lib/node-esm/{settings-4UGMPIRY.mjs → settings-RDYNOKVE.mjs} +8 -5
- package/dist/lib/node-esm/settings-RDYNOKVE.mjs.map +7 -0
- package/dist/lib/node-esm/{state-LXE5XIN4.mjs → state-7HQSNXXQ.mjs} +7 -5
- package/dist/lib/{browser/state-QE7VSJWJ.mjs.map → node-esm/state-7HQSNXXQ.mjs.map} +2 -2
- package/dist/lib/node-esm/types/index.mjs +2 -1
- package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
- package/dist/types/src/blueprints/functions/create.d.ts.map +1 -1
- package/dist/types/src/blueprints/functions/index.d.ts +41 -3
- package/dist/types/src/blueprints/functions/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/functions/open.d.ts +8 -1
- package/dist/types/src/blueprints/functions/open.d.ts.map +1 -1
- package/dist/types/src/blueprints/functions/update.d.ts +16 -3
- package/dist/types/src/blueprints/functions/update.d.ts.map +1 -1
- package/dist/types/src/blueprints/index.d.ts +1 -1
- package/dist/types/src/blueprints/index.d.ts.map +1 -1
- package/dist/types/src/blueprints/markdown-blueprint.d.ts +3 -20
- package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -1
- package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts +3 -2
- package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts.map +1 -1
- package/dist/types/src/capabilities/anchor-sort/index.d.ts +1 -1
- package/dist/types/src/capabilities/anchor-sort/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts +2 -2
- package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-serializer/index.d.ts +1 -1
- package/dist/types/src/capabilities/app-graph-serializer/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts +1 -1
- package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts.map +1 -1
- package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +3 -7
- package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +1 -1
- package/dist/types/src/capabilities/blueprint-definition/index.d.ts +1 -1
- package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/operation-resolver/index.d.ts +1 -1
- package/dist/types/src/capabilities/operation-resolver/index.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-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/settings/index.d.ts +1 -1
- package/dist/types/src/capabilities/settings/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/settings/settings.d.ts +3 -2
- package/dist/types/src/capabilities/settings/settings.d.ts.map +1 -1
- package/dist/types/src/capabilities/state/state.d.ts +1 -1
- package/dist/types/src/cli/plugin.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +2 -2
- package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +5 -3
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +2 -0
- package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +5 -5
- package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +1 -8
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
- package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
- package/dist/types/src/{components → containers}/MarkdownCard/index.d.ts +0 -1
- package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
- package/dist/types/src/{components → containers/MarkdownContainer}/MarkdownContainer.d.ts +6 -6
- package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
- package/dist/types/src/{components → containers/MarkdownContainer}/MarkdownContainer.stories.d.ts +31 -1
- package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
- package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
- package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
- package/dist/types/src/{components → containers}/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
- package/dist/types/src/containers/MarkdownSettings/index.d.ts +3 -0
- package/dist/types/src/containers/MarkdownSettings/index.d.ts.map +1 -0
- package/dist/types/src/containers/index.d.ts +6 -0
- package/dist/types/src/containers/index.d.ts.map +1 -0
- package/dist/types/src/hooks/useExtensions.d.ts +3 -3
- package/dist/types/src/hooks/useExtensions.d.ts.map +1 -1
- package/dist/types/src/hooks/useSelectCurrentThread.d.ts +1 -1
- package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +1 -0
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +30 -0
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/Markdown.d.ts +1 -1
- package/dist/types/src/types/Markdown.d.ts.map +1 -1
- package/dist/types/src/types/MarkdownAction.d.ts +2 -22
- package/dist/types/src/types/MarkdownAction.d.ts.map +1 -1
- package/dist/types/src/types/events.d.ts.map +1 -1
- package/dist/types/src/util.d.ts +1 -1
- package/dist/types/src/util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +64 -57
- package/src/MarkdownPlugin.tsx +29 -38
- package/src/blueprints/functions/create.conversations.json +1 -1
- package/src/blueprints/functions/create.test.ts +24 -57
- package/src/blueprints/functions/create.ts +6 -5
- package/src/blueprints/functions/index.ts +11 -3
- package/src/blueprints/functions/open.ts +10 -10
- package/src/blueprints/functions/update.conversations.json +1 -1
- package/src/blueprints/functions/update.test.ts +133 -67
- package/src/blueprints/functions/update.ts +54 -13
- package/src/blueprints/index.ts +1 -1
- package/src/blueprints/markdown-blueprint.ts +14 -6
- package/src/capabilities/anchor-sort/anchor-sort.ts +3 -2
- package/src/capabilities/app-graph-serializer/app-graph-serializer.ts +5 -4
- package/src/capabilities/artifact-definition/artifact-definition.ts +2 -2
- package/src/capabilities/blueprint-definition/blueprint-definition.ts +6 -14
- package/src/capabilities/operation-resolver/operation-resolver.ts +3 -14
- package/src/capabilities/react-surface/react-surface.tsx +30 -19
- package/src/capabilities/settings/settings.ts +3 -2
- package/src/capabilities/state/state.ts +2 -2
- package/src/cli/plugin.ts +5 -5
- package/src/components/MarkdownEditor/FileUpload.tsx +2 -2
- package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +25 -22
- package/src/components/MarkdownEditor/MarkdownEditor.tsx +44 -17
- package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +6 -5
- package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +13 -13
- package/src/components/index.ts +2 -14
- package/src/{components → containers}/MarkdownCard/MarkdownCard.stories.tsx +17 -7
- package/src/{components → containers}/MarkdownCard/MarkdownCard.tsx +21 -24
- package/src/{components → containers}/MarkdownCard/index.ts +0 -2
- package/src/{components → containers/MarkdownContainer}/MarkdownContainer.stories.tsx +22 -9
- package/src/{components → containers/MarkdownContainer}/MarkdownContainer.tsx +57 -34
- package/src/containers/MarkdownContainer/index.ts +6 -0
- package/src/{components → containers}/MarkdownSettings/MarkdownSettings.tsx +24 -24
- package/src/containers/MarkdownSettings/index.ts +7 -0
- package/src/containers/index.ts +11 -0
- package/src/hooks/useEditorMenuOptions.ts +1 -1
- package/src/hooks/useExtensions.tsx +52 -89
- package/src/hooks/useLinkQuery.ts +3 -3
- package/src/hooks/useSelectCurrentThread.tsx +6 -6
- package/src/index.ts +2 -0
- package/src/meta.ts +1 -1
- package/src/testing.ts +2 -2
- package/src/translations.ts +3 -0
- package/src/types/Markdown.ts +13 -5
- package/src/types/MarkdownAction.ts +3 -18
- package/src/types/capabilities.ts +4 -4
- package/src/types/events.ts +4 -3
- package/src/util.tsx +2 -2
- package/dist/lib/browser/MarkdownCard-WHK3ORP7.mjs +0 -12
- package/dist/lib/browser/MarkdownCard-WHK3ORP7.mjs.map +0 -7
- package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs +0 -12
- package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs.map +0 -7
- package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs.map +0 -7
- package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs.map +0 -7
- package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs +0 -19
- package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs.map +0 -7
- package/dist/lib/browser/chunk-BX73DASG.mjs.map +0 -7
- package/dist/lib/browser/chunk-FWQQW6KU.mjs +0 -144
- package/dist/lib/browser/chunk-FWQQW6KU.mjs.map +0 -7
- package/dist/lib/browser/chunk-JOXYQLKH.mjs.map +0 -7
- package/dist/lib/browser/chunk-KDKXFKDN.mjs.map +0 -7
- package/dist/lib/browser/chunk-LMO5UVKL.mjs.map +0 -7
- package/dist/lib/browser/chunk-S45ULIOG.mjs +0 -101
- package/dist/lib/browser/chunk-S45ULIOG.mjs.map +0 -7
- package/dist/lib/browser/chunk-WIPSLZ6L.mjs.map +0 -7
- package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs.map +0 -7
- package/dist/lib/browser/react-surface-SRPLD3ED.mjs +0 -213
- package/dist/lib/browser/react-surface-SRPLD3ED.mjs.map +0 -7
- package/dist/lib/browser/settings-JY5JE7MI.mjs.map +0 -7
- package/dist/lib/node-esm/MarkdownCard-WJPLQTFS.mjs +0 -13
- package/dist/lib/node-esm/MarkdownCard-WJPLQTFS.mjs.map +0 -7
- package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs +0 -13
- package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs.map +0 -7
- package/dist/lib/node-esm/anchor-sort-G7D5TAI6.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs.map +0 -7
- package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs +0 -20
- package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-3JYPCC7M.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-44VJC3QF.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-D4BCFPKK.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-EYAFC4N7.mjs +0 -145
- package/dist/lib/node-esm/chunk-EYAFC4N7.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-PRV35A7Z.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-RQP7G7XW.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-SDTYEGGL.mjs +0 -102
- package/dist/lib/node-esm/chunk-SDTYEGGL.mjs.map +0 -7
- package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-RONSOJIQ.mjs +0 -214
- package/dist/lib/node-esm/react-surface-RONSOJIQ.mjs.map +0 -7
- package/dist/lib/node-esm/settings-4UGMPIRY.mjs.map +0 -7
- package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownSettings/index.d.ts +0 -2
- package/dist/types/src/components/MarkdownSettings/index.d.ts.map +0 -1
- package/dist/types/src/components/Suggestions.stories.d.ts +0 -11
- package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
- package/src/components/MarkdownSettings/index.ts +0 -5
- package/src/components/Suggestions.stories.tsx +0 -215
- /package/dist/lib/browser/{chunk-CUGDX7KA.mjs.map → chunk-WU3CQIPM.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-W3IIKDV5.mjs.map → chunk-HVAZON2M.mjs.map} +0 -0
- /package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.d.ts +0 -0
- /package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.stories.d.ts +0 -0
- /package/dist/types/src/{components → containers}/MarkdownSettings/MarkdownSettings.d.ts +0 -0
|
@@ -1,214 +0,0 @@
|
|
|
1
|
-
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
-
import "./chunk-RQP7G7XW.mjs";
|
|
3
|
-
import "./chunk-3JYPCC7M.mjs";
|
|
4
|
-
import "./chunk-D4BCFPKK.mjs";
|
|
5
|
-
import "./chunk-SDTYEGGL.mjs";
|
|
6
|
-
import {
|
|
7
|
-
MarkdownCapabilities,
|
|
8
|
-
Markdown_exports,
|
|
9
|
-
meta
|
|
10
|
-
} from "./chunk-PRV35A7Z.mjs";
|
|
11
|
-
|
|
12
|
-
// src/capabilities/react-surface/react-surface.tsx
|
|
13
|
-
import * as Effect from "effect/Effect";
|
|
14
|
-
import React2, { forwardRef, useCallback, useMemo } from "react";
|
|
15
|
-
import { Capability, Common } from "@dxos/app-framework";
|
|
16
|
-
import { useAtomCapability, useAtomCapabilityState, useCapability, useSettingsState } from "@dxos/app-framework/react";
|
|
17
|
-
import { Obj } from "@dxos/echo";
|
|
18
|
-
import { AttentionCapabilities } from "@dxos/plugin-attention";
|
|
19
|
-
import { Text } from "@dxos/schema";
|
|
20
|
-
|
|
21
|
-
// src/components/index.ts
|
|
22
|
-
import { lazy } from "react";
|
|
23
|
-
|
|
24
|
-
// src/components/MarkdownSettings/MarkdownSettings.tsx
|
|
25
|
-
import React from "react";
|
|
26
|
-
import { Input, Select, useTranslation } from "@dxos/react-ui";
|
|
27
|
-
import { ControlGroup, ControlItemInput, ControlPage, ControlSection } from "@dxos/react-ui-form";
|
|
28
|
-
import { EditorInputModes, EditorViewModes } from "@dxos/ui-editor";
|
|
29
|
-
var MarkdownSettings = ({ settings, onSettingsChange }) => {
|
|
30
|
-
const { t } = useTranslation(meta.id);
|
|
31
|
-
return /* @__PURE__ */ React.createElement(ControlPage, null, /* @__PURE__ */ React.createElement(ControlSection, {
|
|
32
|
-
title: t("settings title", {
|
|
33
|
-
ns: meta.id
|
|
34
|
-
})
|
|
35
|
-
}, /* @__PURE__ */ React.createElement(ControlGroup, null, /* @__PURE__ */ React.createElement(ControlItemInput, {
|
|
36
|
-
title: t("default view mode label")
|
|
37
|
-
}, /* @__PURE__ */ React.createElement(Select.Root, {
|
|
38
|
-
value: settings.defaultViewMode,
|
|
39
|
-
onValueChange: (value) => {
|
|
40
|
-
onSettingsChange((s) => ({
|
|
41
|
-
...s,
|
|
42
|
-
defaultViewMode: value
|
|
43
|
-
}));
|
|
44
|
-
}
|
|
45
|
-
}, /* @__PURE__ */ React.createElement(Select.TriggerButton, null), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, EditorViewModes.map((mode) => /* @__PURE__ */ React.createElement(Select.Option, {
|
|
46
|
-
key: mode,
|
|
47
|
-
value: mode
|
|
48
|
-
}, t(`${mode} mode label`, {
|
|
49
|
-
ns: "react-ui-editor"
|
|
50
|
-
})))), /* @__PURE__ */ React.createElement(Select.Arrow, null))))), /* @__PURE__ */ React.createElement(ControlItemInput, {
|
|
51
|
-
title: t("editor input mode label")
|
|
52
|
-
}, /* @__PURE__ */ React.createElement(Select.Root, {
|
|
53
|
-
value: settings.editorInputMode ?? "default",
|
|
54
|
-
onValueChange: (value) => {
|
|
55
|
-
onSettingsChange((s) => ({
|
|
56
|
-
...s,
|
|
57
|
-
editorInputMode: value
|
|
58
|
-
}));
|
|
59
|
-
}
|
|
60
|
-
}, /* @__PURE__ */ React.createElement(Select.TriggerButton, {
|
|
61
|
-
placeholder: t("select editor input mode placeholder")
|
|
62
|
-
}), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, EditorInputModes.map((mode) => /* @__PURE__ */ React.createElement(Select.Option, {
|
|
63
|
-
key: mode,
|
|
64
|
-
value: mode
|
|
65
|
-
}, t(`settings editor input mode ${mode} label`)))), /* @__PURE__ */ React.createElement(Select.Arrow, null))))), /* @__PURE__ */ React.createElement(ControlItemInput, {
|
|
66
|
-
title: t("settings toolbar label")
|
|
67
|
-
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
68
|
-
checked: settings.toolbar,
|
|
69
|
-
onCheckedChange: (checked) => onSettingsChange((s) => ({
|
|
70
|
-
...s,
|
|
71
|
-
toolbar: !!checked
|
|
72
|
-
}))
|
|
73
|
-
})), /* @__PURE__ */ React.createElement(ControlItemInput, {
|
|
74
|
-
title: t("settings numbered headings label")
|
|
75
|
-
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
76
|
-
checked: settings.numberedHeadings,
|
|
77
|
-
onCheckedChange: (checked) => onSettingsChange((s) => ({
|
|
78
|
-
...s,
|
|
79
|
-
numberedHeadings: !!checked
|
|
80
|
-
}))
|
|
81
|
-
})), /* @__PURE__ */ React.createElement(ControlItemInput, {
|
|
82
|
-
title: t("settings folding label")
|
|
83
|
-
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
84
|
-
checked: settings.folding,
|
|
85
|
-
onCheckedChange: (checked) => onSettingsChange((s) => ({
|
|
86
|
-
...s,
|
|
87
|
-
folding: !!checked
|
|
88
|
-
}))
|
|
89
|
-
})), /* @__PURE__ */ React.createElement(ControlItemInput, {
|
|
90
|
-
title: t("settings experimental label")
|
|
91
|
-
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
92
|
-
checked: settings.experimental,
|
|
93
|
-
onCheckedChange: (checked) => onSettingsChange((s) => ({
|
|
94
|
-
...s,
|
|
95
|
-
experimental: !!checked
|
|
96
|
-
}))
|
|
97
|
-
})), /* @__PURE__ */ React.createElement(ControlItemInput, {
|
|
98
|
-
title: t("settings debug label")
|
|
99
|
-
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
100
|
-
checked: settings.debug,
|
|
101
|
-
onCheckedChange: (checked) => onSettingsChange((s) => ({
|
|
102
|
-
...s,
|
|
103
|
-
debug: !!checked
|
|
104
|
-
}))
|
|
105
|
-
})), settings.debug && /* @__PURE__ */ React.createElement(ControlItemInput, {
|
|
106
|
-
title: t("settings debug textarea label", {
|
|
107
|
-
ns: meta.id
|
|
108
|
-
})
|
|
109
|
-
}, /* @__PURE__ */ React.createElement(Input.TextArea, {
|
|
110
|
-
rows: 5,
|
|
111
|
-
value: settings.typewriter,
|
|
112
|
-
onChange: ({ target: { value } }) => onSettingsChange((s) => ({
|
|
113
|
-
...s,
|
|
114
|
-
typewriter: value
|
|
115
|
-
})),
|
|
116
|
-
placeholder: t("settings debug placeholder")
|
|
117
|
-
})))));
|
|
118
|
-
};
|
|
119
|
-
|
|
120
|
-
// src/components/index.ts
|
|
121
|
-
var MarkdownCard = lazy(() => import("./MarkdownCard-WJPLQTFS.mjs"));
|
|
122
|
-
var MarkdownContainer = lazy(() => import("./MarkdownContainer-LUSMORP2.mjs"));
|
|
123
|
-
|
|
124
|
-
// src/capabilities/react-surface/react-surface.tsx
|
|
125
|
-
var react_surface_default = Capability.makeModule(() => Effect.succeed(Capability.contributes(Common.Capability.ReactSurface, [
|
|
126
|
-
Common.createSurface({
|
|
127
|
-
id: `${meta.id}/surface/document`,
|
|
128
|
-
role: [
|
|
129
|
-
"article",
|
|
130
|
-
"section",
|
|
131
|
-
"tabpanel"
|
|
132
|
-
],
|
|
133
|
-
filter: (data) => Obj.instanceOf(Markdown_exports.Document, data.subject) && !data.variant,
|
|
134
|
-
component: ({ data, role, ref }) => {
|
|
135
|
-
return /* @__PURE__ */ React2.createElement(Container, {
|
|
136
|
-
id: Obj.getDXN(data.subject).toString(),
|
|
137
|
-
subject: data.subject,
|
|
138
|
-
role,
|
|
139
|
-
ref
|
|
140
|
-
});
|
|
141
|
-
}
|
|
142
|
-
}),
|
|
143
|
-
Common.createSurface({
|
|
144
|
-
id: `${meta.id}/surface/text`,
|
|
145
|
-
role: [
|
|
146
|
-
"article",
|
|
147
|
-
"section",
|
|
148
|
-
"tabpanel"
|
|
149
|
-
],
|
|
150
|
-
filter: (data) => typeof data.id === "string" && Obj.instanceOf(Text.Text, data.subject),
|
|
151
|
-
component: ({ data, role }) => {
|
|
152
|
-
return /* @__PURE__ */ React2.createElement(Container, {
|
|
153
|
-
id: data.id,
|
|
154
|
-
subject: data.subject,
|
|
155
|
-
role
|
|
156
|
-
});
|
|
157
|
-
}
|
|
158
|
-
}),
|
|
159
|
-
Common.createSurface({
|
|
160
|
-
id: `${meta.id}/surface/plugin-settings`,
|
|
161
|
-
role: "article",
|
|
162
|
-
filter: (data) => Common.Capability.isSettings(data.subject) && data.subject.prefix === meta.id,
|
|
163
|
-
component: ({ data: { subject } }) => {
|
|
164
|
-
const { settings, updateSettings } = useSettingsState(subject.atom);
|
|
165
|
-
return /* @__PURE__ */ React2.createElement(MarkdownSettings, {
|
|
166
|
-
settings,
|
|
167
|
-
onSettingsChange: updateSettings
|
|
168
|
-
});
|
|
169
|
-
}
|
|
170
|
-
}),
|
|
171
|
-
Common.createSurface({
|
|
172
|
-
id: `${meta.id}/surface/preview`,
|
|
173
|
-
role: "card--content",
|
|
174
|
-
filter: (data) => Obj.instanceOf(Markdown_exports.Document, data.subject) || Obj.instanceOf(Text.Text, data.subject),
|
|
175
|
-
component: ({ data }) => /* @__PURE__ */ React2.createElement(MarkdownCard, data)
|
|
176
|
-
})
|
|
177
|
-
])));
|
|
178
|
-
var Container = /* @__PURE__ */ forwardRef(({ id, subject, role }, forwardedRef) => {
|
|
179
|
-
const selectionManager = useCapability(AttentionCapabilities.Selection);
|
|
180
|
-
const settings = useAtomCapability(MarkdownCapabilities.Settings);
|
|
181
|
-
const [state, setState] = useAtomCapabilityState(MarkdownCapabilities.State);
|
|
182
|
-
const editorState = useCapability(MarkdownCapabilities.EditorState);
|
|
183
|
-
const extensions = useCapability(MarkdownCapabilities.Extensions);
|
|
184
|
-
const extensionProviders = useMemo(() => extensions.flat(), [
|
|
185
|
-
extensions
|
|
186
|
-
]);
|
|
187
|
-
const viewMode = id && state.viewMode[id] || settings?.defaultViewMode || "source";
|
|
188
|
-
const handleViewModeChange = useCallback((mode) => setState((current) => ({
|
|
189
|
-
...current,
|
|
190
|
-
viewMode: {
|
|
191
|
-
...current.viewMode,
|
|
192
|
-
[id]: mode
|
|
193
|
-
}
|
|
194
|
-
})), [
|
|
195
|
-
id,
|
|
196
|
-
setState
|
|
197
|
-
]);
|
|
198
|
-
return /* @__PURE__ */ React2.createElement(MarkdownContainer, {
|
|
199
|
-
role,
|
|
200
|
-
subject,
|
|
201
|
-
id,
|
|
202
|
-
settings,
|
|
203
|
-
selectionManager,
|
|
204
|
-
extensionProviders,
|
|
205
|
-
editorStateStore: editorState,
|
|
206
|
-
viewMode,
|
|
207
|
-
onViewModeChange: handleViewModeChange,
|
|
208
|
-
ref: forwardedRef
|
|
209
|
-
});
|
|
210
|
-
});
|
|
211
|
-
export {
|
|
212
|
-
react_surface_default as default
|
|
213
|
-
};
|
|
214
|
-
//# sourceMappingURL=react-surface-RONSOJIQ.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/react-surface/react-surface.tsx", "../../../src/components/index.ts", "../../../src/components/MarkdownSettings/MarkdownSettings.tsx"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\nimport React, { forwardRef, useCallback, useMemo } from 'react';\n\nimport { Capability, Common } from '@dxos/app-framework';\nimport {\n type SurfaceComponentProps,\n useAtomCapability,\n useAtomCapabilityState,\n useCapability,\n useSettingsState,\n} from '@dxos/app-framework/react';\nimport { Obj } from '@dxos/echo';\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { Text } from '@dxos/schema';\nimport { type EditorViewMode } from '@dxos/ui-editor';\n\nimport { MarkdownCard, MarkdownContainer, type MarkdownContainerProps, MarkdownSettings } from '../../components';\nimport { meta } from '../../meta';\nimport { Markdown, MarkdownCapabilities } from '../../types';\n\nexport default Capability.makeModule(() =>\n Effect.succeed(\n Capability.contributes(Common.Capability.ReactSurface, [\n Common.createSurface({\n id: `${meta.id}/surface/document`,\n role: ['article', 'section', 'tabpanel'],\n filter: (data): data is { subject: Markdown.Document; variant: undefined } =>\n Obj.instanceOf(Markdown.Document, data.subject) && !data.variant,\n component: ({ data, role, ref }) => {\n return <Container id={Obj.getDXN(data.subject).toString()} subject={data.subject} role={role} ref={ref} />;\n },\n }),\n Common.createSurface({\n id: `${meta.id}/surface/text`,\n role: ['article', 'section', 'tabpanel'],\n filter: (data): data is { id: string; subject: Text.Text } =>\n typeof data.id === 'string' && Obj.instanceOf(Text.Text, data.subject),\n component: ({ data, role }) => {\n return <Container id={data.id} subject={data.subject} role={role} />;\n },\n }),\n Common.createSurface({\n id: `${meta.id}/surface/plugin-settings`,\n role: 'article',\n filter: (data): data is { subject: Common.Capability.Settings } =>\n Common.Capability.isSettings(data.subject) && data.subject.prefix === meta.id,\n component: ({ data: { subject } }) => {\n const { settings, updateSettings } = useSettingsState<Markdown.Settings>(subject.atom);\n return <MarkdownSettings settings={settings} onSettingsChange={updateSettings} />;\n },\n }),\n Common.createSurface({\n id: `${meta.id}/surface/preview`,\n role: 'card--content',\n filter: (data): data is { subject: Markdown.Document | Text.Text } =>\n Obj.instanceOf(Markdown.Document, data.subject) || Obj.instanceOf(Text.Text, data.subject),\n component: ({ data }) => <MarkdownCard {...data} />,\n }),\n ]),\n ),\n);\n\n/**\n * Common wrapper.\n */\nconst Container = forwardRef<HTMLDivElement, SurfaceComponentProps<Markdown.Document | Text.Text, { id: string }>>(\n ({ id, subject, role }, forwardedRef) => {\n const selectionManager = useCapability(AttentionCapabilities.Selection);\n const settings = useAtomCapability(MarkdownCapabilities.Settings);\n const [state, setState] = useAtomCapabilityState(MarkdownCapabilities.State);\n const editorState = useCapability(MarkdownCapabilities.EditorState);\n const extensions = useCapability(MarkdownCapabilities.Extensions);\n const extensionProviders = useMemo(() => extensions.flat(), [extensions]);\n\n const viewMode: EditorViewMode = (id && state.viewMode[id]) || settings?.defaultViewMode || 'source';\n const handleViewModeChange = useCallback<NonNullable<MarkdownContainerProps['onViewModeChange']>>(\n (mode) => setState((current) => ({ ...current, viewMode: { ...current.viewMode, [id]: mode } })),\n [id, setState],\n );\n\n return (\n <MarkdownContainer\n role={role}\n subject={subject}\n id={id}\n settings={settings}\n selectionManager={selectionManager}\n extensionProviders={extensionProviders}\n editorStateStore={editorState}\n viewMode={viewMode}\n onViewModeChange={handleViewModeChange}\n ref={forwardedRef}\n />\n );\n },\n);\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type LazyExoticComponent, lazy } from 'react';\n\nimport { type MarkdownCard as MarkdownCardType } from './MarkdownCard';\nimport { type MarkdownContainer as MarkdownContainerType } from './MarkdownContainer';\n\nexport * from './MarkdownCard';\nexport * from './MarkdownContainer';\nexport * from './MarkdownSettings';\n\nexport const MarkdownCard: LazyExoticComponent<typeof MarkdownCardType> = lazy(() => import('./MarkdownCard'));\nexport const MarkdownContainer: LazyExoticComponent<typeof MarkdownContainerType> = lazy(\n () => import('./MarkdownContainer'),\n);\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { ControlGroup, ControlItemInput, ControlPage, ControlSection } from '@dxos/react-ui-form';\nimport { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/ui-editor';\n\nimport { meta } from '../../meta';\nimport { type Markdown } from '../../types';\n\nexport type MarkdownSettingsComponentProps = {\n settings: Markdown.Settings;\n onSettingsChange: (fn: (current: Markdown.Settings) => Markdown.Settings) => void;\n};\n\nexport const MarkdownSettings = ({ settings, onSettingsChange }: MarkdownSettingsComponentProps) => {\n const { t } = useTranslation(meta.id);\n\n // TODO(wittjosiah): Add skill test confirmation for entering vim mode.\n return (\n <ControlPage>\n <ControlSection title={t('settings title', { ns: meta.id })}>\n <ControlGroup>\n <ControlItemInput title={t('default view mode label')}>\n <Select.Root\n value={settings.defaultViewMode}\n onValueChange={(value) => {\n onSettingsChange((s) => ({ ...s, defaultViewMode: value as EditorViewMode }));\n }}\n >\n <Select.TriggerButton />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorViewModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`${mode} mode label`, { ns: 'react-ui-editor' })}\n </Select.Option>\n ))}\n </Select.Viewport>\n <Select.Arrow />\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </ControlItemInput>\n\n <ControlItemInput title={t('editor input mode label')}>\n <Select.Root\n value={settings.editorInputMode ?? 'default'}\n onValueChange={(value) => {\n onSettingsChange((s) => ({ ...s, editorInputMode: value as EditorInputMode }));\n }}\n >\n <Select.TriggerButton placeholder={t('select editor input mode placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorInputModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`settings editor input mode ${mode} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n <Select.Arrow />\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </ControlItemInput>\n\n <ControlItemInput title={t('settings toolbar label')}>\n <Input.Switch\n checked={settings.toolbar}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, toolbar: !!checked }))}\n />\n </ControlItemInput>\n\n <ControlItemInput title={t('settings numbered headings label')}>\n <Input.Switch\n checked={settings.numberedHeadings}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, numberedHeadings: !!checked }))}\n />\n </ControlItemInput>\n\n <ControlItemInput title={t('settings folding label')}>\n <Input.Switch\n checked={settings.folding}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, folding: !!checked }))}\n />\n </ControlItemInput>\n\n <ControlItemInput title={t('settings experimental label')}>\n <Input.Switch\n checked={settings.experimental}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, experimental: !!checked }))}\n />\n </ControlItemInput>\n\n <ControlItemInput title={t('settings debug label')}>\n <Input.Switch\n checked={settings.debug}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, debug: !!checked }))}\n />\n </ControlItemInput>\n\n {settings.debug && (\n <ControlItemInput title={t('settings debug textarea label', { ns: meta.id })}>\n <Input.TextArea\n rows={5}\n value={settings.typewriter}\n onChange={({ target: { value } }) => onSettingsChange((s) => ({ ...s, typewriter: value }))}\n placeholder={t('settings debug placeholder')}\n />\n </ControlItemInput>\n )}\n </ControlGroup>\n </ControlSection>\n </ControlPage>\n );\n};\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["Effect", "React", "forwardRef", "useCallback", "useMemo", "Capability", "Common", "useAtomCapability", "useAtomCapabilityState", "useCapability", "useSettingsState", "Obj", "AttentionCapabilities", "Text", "lazy", "React", "Input", "Select", "useTranslation", "ControlGroup", "ControlItemInput", "ControlPage", "ControlSection", "EditorInputModes", "EditorViewModes", "MarkdownSettings", "settings", "onSettingsChange", "t", "useTranslation", "meta", "id", "ControlPage", "ControlSection", "title", "ns", "ControlGroup", "ControlItemInput", "Select", "Root", "value", "defaultViewMode", "onValueChange", "s", "TriggerButton", "Portal", "Content", "Viewport", "EditorViewModes", "map", "mode", "Option", "key", "Arrow", "editorInputMode", "placeholder", "EditorInputModes", "Input", "Switch", "checked", "toolbar", "onCheckedChange", "numberedHeadings", "folding", "experimental", "debug", "TextArea", "rows", "typewriter", "onChange", "target", "MarkdownCard", "lazy", "MarkdownContainer", "Capability", "makeModule", "succeed", "contributes", "Common", "ReactSurface", "createSurface", "id", "meta", "role", "filter", "data", "Obj", "instanceOf", "Markdown", "Document", "subject", "variant", "component", "ref", "React", "Container", "getDXN", "toString", "Text", "isSettings", "prefix", "settings", "updateSettings", "useSettingsState", "atom", "MarkdownSettings", "onSettingsChange", "MarkdownCard", "forwardRef", "forwardedRef", "selectionManager", "useCapability", "AttentionCapabilities", "Selection", "useAtomCapability", "MarkdownCapabilities", "Settings", "state", "setState", "useAtomCapabilityState", "State", "editorState", "EditorState", "extensions", "Extensions", "extensionProviders", "useMemo", "flat", "viewMode", "defaultViewMode", "handleViewModeChange", "useCallback", "mode", "current", "MarkdownContainer", "editorStateStore", "onViewModeChange"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/settings/settings.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capability, Common } from '@dxos/app-framework';\nimport { createKvsStore } from '@dxos/effect';\n\nimport { meta } from '../../meta';\nimport { Markdown, MarkdownCapabilities } from '../../types';\n\nexport default Capability.makeModule(() =>\n Effect.sync(() => {\n const settingsAtom = createKvsStore({\n key: meta.id,\n schema: Markdown.Settings,\n defaultValue: () => ({\n defaultViewMode: 'preview' as const,\n toolbar: true,\n numberedHeadings: true,\n folding: true,\n experimental: false,\n }),\n });\n\n return [\n Capability.contributes(MarkdownCapabilities.Settings, settingsAtom),\n Capability.contributes(Common.Capability.Settings, {\n prefix: meta.id,\n schema: Markdown.Settings,\n atom: settingsAtom,\n }),\n ];\n }),\n);\n"],
|
|
5
|
-
"mappings": ";;;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,YAAYC,cAAc;AACnC,SAASC,sBAAsB;AAK/B,IAAA,mBAAeC,WAAWC,WAAW,MAC5BC,YAAK,MAAA;AACV,QAAMC,eAAeC,eAAe;IAClCC,KAAKC,KAAKC;IACVC,QAAQC,iBAASC;IACjBC,cAAc,OAAO;MACnBC,iBAAiB;MACjBC,SAAS;MACTC,kBAAkB;MAClBC,SAAS;MACTC,cAAc;IAChB;EACF,CAAA;AAEA,SAAO;IACLhB,WAAWiB,YAAYC,qBAAqBR,UAAUP,YAAAA;IACtDH,WAAWiB,YAAYE,OAAOnB,WAAWU,UAAU;MACjDU,QAAQd,KAAKC;MACbC,QAAQC,iBAASC;MACjBW,MAAMlB;IACR,CAAA;;AAEJ,CAAA,CAAA;",
|
|
6
|
-
"names": ["Effect", "Capability", "Common", "createKvsStore", "Capability", "makeModule", "sync", "settingsAtom", "createKvsStore", "key", "meta", "id", "schema", "Markdown", "Settings", "defaultValue", "defaultViewMode", "toolbar", "numberedHeadings", "folding", "experimental", "contributes", "MarkdownCapabilities", "Common", "prefix", "atom"]
|
|
7
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MarkdownCard.d.ts","sourceRoot":"","sources":["../../../../../src/components/MarkdownCard/MarkdownCard.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAkB,MAAM,OAAO,CAAC;AAKvC,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAGpC,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAIvC,MAAM,MAAM,iBAAiB,GAAG;IAAE,OAAO,EAAE,QAAQ,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAA;CAAE,CAAC;AAE3E,eAAO,MAAM,YAAY,GAAI,aAAa,iBAAiB,sBAqB1D,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MarkdownCard.stories.d.ts","sourceRoot":"","sources":["../../../../../src/components/MarkdownCard/MarkdownCard.stories.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,IAAI,EAAE,KAAK,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjE,OAAO,KAAkB,MAAM,OAAO,CAAC;AAWvC,OAAO,EAAgB,KAAK,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAKtE,QAAA,MAAM,iBAAiB,GAAI,aAAa,IAAI,CAAC,iBAAiB,EAAE,SAAS,CAAC,sBAczE,CAAC;AAEF,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,iBAAiB,CAcxC,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAAU,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/MarkdownCard/index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE9C,cAAc,gBAAgB,CAAC;AAE/B,eAAe,YAAY,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MarkdownContainer.d.ts","sourceRoot":"","sources":["../../../../src/components/MarkdownContainer.tsx"],"names":[],"mappings":"AAMA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAGnD,OAAO,EAAE,KAAK,qBAAqB,EAAgC,MAAM,2BAA2B,CAAC;AAIrG,OAAO,EAAE,KAAK,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAEjE,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAGpC,OAAO,EAAE,QAAQ,EAAwB,KAAK,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAEpF,OAAO,EAAkB,KAAK,0BAA0B,EAAE,KAAK,uBAAuB,EAAE,MAAM,kBAAkB,CAAC;AAEjH,MAAM,MAAM,sBAAsB,GAAG,qBAAqB,CACxD,QAAQ,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,EAC7B;IACE,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,QAAQ,CAAC,QAAQ,CAAC;IAC5B,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;CACrC,GAAG,IAAI,CAAC,uBAAuB,EAAE,UAAU,GAAG,kBAAkB,CAAC,GAChE,IAAI,CAAC,0BAA0B,EAAE,kBAAkB,CAAC,GACpD,IAAI,CAAC,mBAAmB,EAAE,oBAAoB,CAAC,CAClD,CAAC;AAEF,eAAO,MAAM,iBAAiB;;;;;;;;;;;QARtB,MAAM;cACA,QAAQ,CAAC,QAAQ;uBACR,gBAAgB;kNAiFtC,CAAC;AAEF,eAAe,iBAAiB,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MarkdownContainer.stories.d.ts","sourceRoot":"","sources":["../../../../src/components/MarkdownContainer.stories.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAa,KAAK,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAEjE,OAAO,KAAkB,MAAM,OAAO,CAAC;AAoBvC,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AA2BpC,QAAA,MAAM,IAAI;;;;;;;;;;;yBA7CQ,CAAO,QAAQ,CAAC,QAAQ,CAAC,QACtC,CAAC;;;;;;;;;;yBAM6B,CAC9B,IAAI,CAAC,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+FwB,CAAC;AAEtC,eAAe,IAAI,CAAC;AAEpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAKrB,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/MarkdownSettings/index.ts"],"names":[],"mappings":"AAIA,cAAc,oBAAoB,CAAC"}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { type Meta } from '@storybook/react-vite';
|
|
2
|
-
import React from 'react';
|
|
3
|
-
declare const DefaultStory: ({ document, chat }: {
|
|
4
|
-
document: string;
|
|
5
|
-
chat: string;
|
|
6
|
-
}) => React.JSX.Element | null;
|
|
7
|
-
declare const storybook: Meta<typeof DefaultStory>;
|
|
8
|
-
export default storybook;
|
|
9
|
-
type Story = Meta<typeof DefaultStory>;
|
|
10
|
-
export declare const Default: Story;
|
|
11
|
-
//# sourceMappingURL=Suggestions.stories.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Suggestions.stories.d.ts","sourceRoot":"","sources":["../../../../src/components/Suggestions.stories.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,IAAI,EAAE,MAAM,uBAAuB,CAAC;AAMlD,OAAO,KAAgD,MAAM,OAAO,CAAC;AAoGrE,QAAA,MAAM,YAAY,GAAI,oBAAoB;IAAE,QAAQ,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,6BAwC3E,CAAC;AAEF,QAAA,MAAM,SAAS,EAAE,IAAI,CAAC,OAAO,YAAY,CA6BxC,CAAC;AAEF,eAAe,SAAS,CAAC;AAEzB,KAAK,KAAK,GAAG,IAAI,CAAC,OAAO,YAAY,CAAC,CAAC;AAEvC,eAAO,MAAM,OAAO,EAAE,KAcrB,CAAC"}
|
|
@@ -1,215 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2023 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { type Meta } from '@storybook/react-vite';
|
|
6
|
-
import * as Effect from 'effect/Effect';
|
|
7
|
-
import * as Function from 'effect/Function';
|
|
8
|
-
import * as Match from 'effect/Match';
|
|
9
|
-
import * as Option from 'effect/Option';
|
|
10
|
-
import * as Schema from 'effect/Schema';
|
|
11
|
-
import React, { type FC, useEffect, useMemo, useState } from 'react';
|
|
12
|
-
|
|
13
|
-
import { useAtomCapability, useCapability } from '@dxos/app-framework/react';
|
|
14
|
-
import { withPluginManager } from '@dxos/app-framework/testing';
|
|
15
|
-
import { Obj, Ref, Type } from '@dxos/echo';
|
|
16
|
-
import { createDocAccessor, toCursorRange } from '@dxos/echo-db';
|
|
17
|
-
import { invariant } from '@dxos/invariant';
|
|
18
|
-
import { ClientPlugin } from '@dxos/plugin-client';
|
|
19
|
-
import { PreviewPlugin } from '@dxos/plugin-preview';
|
|
20
|
-
import { StorybookPlugin, corePlugins } from '@dxos/plugin-testing';
|
|
21
|
-
import { faker } from '@dxos/random';
|
|
22
|
-
import { useQueue, useSpace } from '@dxos/react-client/echo';
|
|
23
|
-
import { IconButton, Toolbar } from '@dxos/react-ui';
|
|
24
|
-
import { withTheme } from '@dxos/react-ui/testing';
|
|
25
|
-
import { useTextEditor } from '@dxos/react-ui-editor';
|
|
26
|
-
import { Layout } from '@dxos/react-ui-mosaic';
|
|
27
|
-
import { render } from '@dxos/storybook-utils';
|
|
28
|
-
import { Message } from '@dxos/types';
|
|
29
|
-
import { type EditorSelection, type Range } from '@dxos/ui-editor';
|
|
30
|
-
|
|
31
|
-
import { MarkdownPlugin } from '../MarkdownPlugin';
|
|
32
|
-
import { translations } from '../translations';
|
|
33
|
-
import { Markdown, MarkdownCapabilities } from '../types';
|
|
34
|
-
|
|
35
|
-
import { MarkdownContainer } from './MarkdownContainer';
|
|
36
|
-
|
|
37
|
-
faker.seed(1);
|
|
38
|
-
|
|
39
|
-
const TestItem = Schema.Struct({
|
|
40
|
-
title: Schema.String.annotations({
|
|
41
|
-
title: 'Title',
|
|
42
|
-
description: 'Product title',
|
|
43
|
-
}),
|
|
44
|
-
description: Schema.String.annotations({
|
|
45
|
-
title: 'Description',
|
|
46
|
-
description: 'Product description',
|
|
47
|
-
}),
|
|
48
|
-
}).pipe(
|
|
49
|
-
Type.object({
|
|
50
|
-
typename: 'dxos.org/type/Test',
|
|
51
|
-
version: '0.1.0',
|
|
52
|
-
}),
|
|
53
|
-
);
|
|
54
|
-
|
|
55
|
-
const TestChat: FC<{ doc: Markdown.Document; content: string }> = ({ doc, content }) => {
|
|
56
|
-
const { parentRef } = useTextEditor({ initialValue: content });
|
|
57
|
-
const editorState = useCapability(MarkdownCapabilities.EditorState);
|
|
58
|
-
|
|
59
|
-
const space = useSpace();
|
|
60
|
-
const queueDxn = useMemo(() => space && space.queues.create().dxn, [space]);
|
|
61
|
-
const queue = useQueue<Message.Message>(queueDxn);
|
|
62
|
-
|
|
63
|
-
const handleInsert = async () => {
|
|
64
|
-
invariant(space);
|
|
65
|
-
invariant(queue);
|
|
66
|
-
await queue.append([
|
|
67
|
-
Obj.make(Message.Message, {
|
|
68
|
-
created: new Date().toISOString(),
|
|
69
|
-
sender: { role: 'assistant' },
|
|
70
|
-
blocks: [{ _tag: 'text', text: 'Hello' }],
|
|
71
|
-
}),
|
|
72
|
-
]);
|
|
73
|
-
const message = queue.objects.at(-1);
|
|
74
|
-
invariant(message);
|
|
75
|
-
|
|
76
|
-
const text = await doc.content.load();
|
|
77
|
-
const accessor = createDocAccessor(text, ['content']);
|
|
78
|
-
const cursor = Function.pipe(
|
|
79
|
-
editorState.getState(Obj.getDXN(doc).toString())?.selection,
|
|
80
|
-
Option.fromNullable,
|
|
81
|
-
Option.map(selectionToRange),
|
|
82
|
-
Option.map((range) => toCursorRange(accessor, range.from, range.to)),
|
|
83
|
-
Option.getOrUndefined,
|
|
84
|
-
);
|
|
85
|
-
|
|
86
|
-
// {
|
|
87
|
-
// const ref = refFromDXN(new DXN(DXN.kind.QUEUE, [...queue.dxn.parts, message.id]));
|
|
88
|
-
// const message = deref(ref);
|
|
89
|
-
// }
|
|
90
|
-
|
|
91
|
-
// void dispatch(
|
|
92
|
-
// createIntent(CollaborationActions.InsertContent, {
|
|
93
|
-
// target: doc as any as TestSchema.Expando,
|
|
94
|
-
// object: Ref.fromDXN(new DXN(DXN.kind.QUEUE, [...queue.dxn.parts, message.id])),
|
|
95
|
-
// at: cursor,
|
|
96
|
-
// label: 'Proposal',
|
|
97
|
-
// }),
|
|
98
|
-
// );
|
|
99
|
-
};
|
|
100
|
-
|
|
101
|
-
return (
|
|
102
|
-
<Layout.Main toolbar>
|
|
103
|
-
<Toolbar.Root>
|
|
104
|
-
<IconButton icon='ph--plus--regular' disabled={!queue} label='Insert' onClick={handleInsert} />
|
|
105
|
-
</Toolbar.Root>
|
|
106
|
-
<div ref={parentRef} className='p-4' />
|
|
107
|
-
</Layout.Main>
|
|
108
|
-
);
|
|
109
|
-
};
|
|
110
|
-
|
|
111
|
-
const DefaultStory = ({ document, chat }: { document: string; chat: string }) => {
|
|
112
|
-
const space = useSpace();
|
|
113
|
-
const [doc, setDoc] = useState<Markdown.Document>();
|
|
114
|
-
const settings = useAtomCapability(MarkdownCapabilities.Settings);
|
|
115
|
-
const editorState = useCapability(MarkdownCapabilities.EditorState);
|
|
116
|
-
|
|
117
|
-
useEffect(() => {
|
|
118
|
-
if (!space) {
|
|
119
|
-
return undefined;
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
const doc = space.db.add(
|
|
123
|
-
Markdown.make({
|
|
124
|
-
name: 'Test',
|
|
125
|
-
content: document.replaceAll(/\[(\w+)\]/g, (_, label) => {
|
|
126
|
-
const obj = space.db.add(
|
|
127
|
-
Obj.make(TestItem, {
|
|
128
|
-
title: label,
|
|
129
|
-
description: faker.lorem.paragraph(),
|
|
130
|
-
}),
|
|
131
|
-
);
|
|
132
|
-
const dxn = Ref.make(obj).dxn.toString();
|
|
133
|
-
return `[${label}](${dxn})`;
|
|
134
|
-
}),
|
|
135
|
-
}),
|
|
136
|
-
);
|
|
137
|
-
|
|
138
|
-
setDoc(doc);
|
|
139
|
-
}, [space]);
|
|
140
|
-
|
|
141
|
-
if (!space || !doc) {
|
|
142
|
-
return null;
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
return (
|
|
146
|
-
<div className='grid grid-cols-2 bs-full overflow-hidden'>
|
|
147
|
-
<MarkdownContainer id={doc.id} subject={doc} settings={settings} editorStateStore={editorState} />
|
|
148
|
-
<TestChat doc={doc} content={chat} />
|
|
149
|
-
</div>
|
|
150
|
-
);
|
|
151
|
-
};
|
|
152
|
-
|
|
153
|
-
const storybook: Meta<typeof DefaultStory> = {
|
|
154
|
-
title: 'plugins/plugin-markdown/Suggestions',
|
|
155
|
-
render: render(DefaultStory),
|
|
156
|
-
decorators: [
|
|
157
|
-
withTheme,
|
|
158
|
-
withPluginManager({
|
|
159
|
-
plugins: [
|
|
160
|
-
...corePlugins(),
|
|
161
|
-
StorybookPlugin({}),
|
|
162
|
-
ClientPlugin({
|
|
163
|
-
types: [Markdown.Document, TestItem],
|
|
164
|
-
onClientInitialized: ({ client }) =>
|
|
165
|
-
Effect.gen(function* () {
|
|
166
|
-
yield* Effect.promise(() => client.halo.createIdentity());
|
|
167
|
-
}),
|
|
168
|
-
}),
|
|
169
|
-
|
|
170
|
-
MarkdownPlugin(),
|
|
171
|
-
PreviewPlugin(),
|
|
172
|
-
],
|
|
173
|
-
}),
|
|
174
|
-
],
|
|
175
|
-
parameters: {
|
|
176
|
-
layout: 'fullscreen',
|
|
177
|
-
controls: {
|
|
178
|
-
disable: true,
|
|
179
|
-
},
|
|
180
|
-
translations,
|
|
181
|
-
},
|
|
182
|
-
};
|
|
183
|
-
|
|
184
|
-
export default storybook;
|
|
185
|
-
|
|
186
|
-
type Story = Meta<typeof DefaultStory>;
|
|
187
|
-
|
|
188
|
-
export const Default: Story = {
|
|
189
|
-
args: {
|
|
190
|
-
chat: 'Hello\n',
|
|
191
|
-
document: [
|
|
192
|
-
'# Test',
|
|
193
|
-
'',
|
|
194
|
-
faker.lorem.paragraph(1),
|
|
195
|
-
'',
|
|
196
|
-
'This is a [DXOS] story that tests [ECHO] references inside the Markdown plugin.',
|
|
197
|
-
'',
|
|
198
|
-
faker.lorem.paragraph(3),
|
|
199
|
-
'',
|
|
200
|
-
].join('\n'),
|
|
201
|
-
},
|
|
202
|
-
};
|
|
203
|
-
|
|
204
|
-
// TODO(wittjosiah): Factor out.
|
|
205
|
-
const selectionToRange = Match.type<EditorSelection>().pipe(
|
|
206
|
-
Match.when(
|
|
207
|
-
({ head, anchor }) => (head ? head > anchor : false),
|
|
208
|
-
({ head, anchor }) => ({ from: anchor, to: head! }) as Range,
|
|
209
|
-
),
|
|
210
|
-
Match.when(
|
|
211
|
-
({ head, anchor }) => (head ? head < anchor : false),
|
|
212
|
-
({ head, anchor }) => ({ from: head!, to: anchor }) as Range,
|
|
213
|
-
),
|
|
214
|
-
Match.orElse(({ anchor }) => ({ from: anchor, to: anchor }) as Range),
|
|
215
|
-
);
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|